Java List集合特有方法程序用法
package Collection; /*
Collection
|--List:元素是有序的,元素可以重复。因为该集合体系有索引
| |--ArrayList:底层的数据结构使用的是数组结构 特点:查询,修改速度很快,但是增删稍慢。线程不同步
| |--LinkedList:底层使用的是链表的数据结构 特点:增删速度很快,查询稍慢
| |--Vector:底层是数组数据结构。线程同步。被ArrayList替代了
|--set:元素是无序,元素可以重复 List:集合特有的方法,凡是可以操作角标的方法都是该体系特有的方法 增
add(index,element);
addall(index,Collection); 删
remove(index); 改
set(index,element); 查
get(index);
subList(from , to);
listIterator(); List 集合特有的迭代器。ListIterator是Iterator的子接口
在迭代时,不可以通过集合对象的方法操作集合中的元素。因为会发生 Concurrent~~~ 异常。
所以,在迭代时,只能用迭代器的方法操作元素,可是 Iterator 方法是有限的,只能对元素
进行判断,取出,删除的操作。
如果想要其他的操作如添加,修改等,就要使用其子接口,Listiterator.
该接口只能通过List集合的listIterator方法获取。 */ import java.util.*; public class ListDemo
{ /**
* @param args
*/ public static void sop(Object obj)
{
System.out.println(obj);
} public static void method()
{
ArrayList<String> al = new ArrayList<String>(); // add
al.add("java01");
al.add("java02");
al.add("java03"); sop("原集合:"+al);
// 在指定位置添加元素
al.add(1,"java09"); // 删除指定元素
al.remove(2); // 修改元素
al.set(0, "Java10"); // 通过角标获取元素
sop("get(1):"+al.get(0));
sop(al); // 获取所有元素 for循环
for(int x = 0;x<al.size();x++)
{
System.out.println("al("+x+")="+al.get(x));
} // 迭代器
Iterator<String> it = al.iterator();
while (it.hasNext())
{
sop("next: "+it.next());
} // 通过 indexof 获取对象的位置
sop("indexof = "+al.indexOf("Java10"));
List<String> sub = al.subList(0, 2);
sop("sub = "+sub);
} public static void main(String[] args)
{
// TODO Auto-generated method stub // 演示列表迭代器
ArrayList<String> alArrayList = new ArrayList<String>();
alArrayList.add("Java01");
alArrayList.add("Java02");
alArrayList.add("Java03"); sop(alArrayList); // 使用 ListIterator 接口
ListIterator<String> li = alArrayList.listIterator(); // 有没有前一个元素
// sop("hasPrevious()"+li.hasPrevious());
while (li.hasNext())
{
Object obj = li.next();
if(obj.equals("Java01"))
{
// 添加
// li.add("Java11"); // 修改
li.set("Java11");
}
} while (li.hasPrevious())
{
sop("Pre::"+li.previous());
} // 有没有后一个元素
// sop("hasNext():"+li.hasNext());
// sop("hasPrevious()"+li.hasPrevious()); sop(alArrayList);
/*
* 使用 Iterator 接口
// 在迭代过程中,准备添加或者删除元素
Iterator<String> iterator = alArrayList.iterator();
while (iterator.hasNext())
{
// sop("next: "+iterator.next());
Object obj = iterator.next();
if (obj.equals("Java01"))
{
// alArrayList.add("Java11");
// 将 Java01 的引用从集合中删除了
iterator.remove();
}
sop("Obj = "+obj);
}
*/
}
}
Java List集合特有方法程序用法的更多相关文章
- Java LinkedList特有方法程序小解 && 使用LinkedList 模拟一个堆栈或者队列数据结构。
package Collection; import java.util.LinkedList; /* LinkedList:特有的方法 addFirst()/addLast(); getFirst( ...
- Java中有关clone方法的用法
一.clone在数组基本数据类型中的使用 public class Main { public static void main(String[] args) { int[] arr= {7,8,9} ...
- java.util 集合框架集合
java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Colle ...
- Java.io.ObjectOutputStream.writeObject()方法实例
java.io.ObjectOutputStream.writeObject(Object obj) 方法将指定对象写入ObjectOutputStream.该对象的类,类的签名,以及类及其所有超类型 ...
- java中集合格式及json格式的特点和转换
作者原创:转载请注明出处 今天在写代码,遇到一个难点,由于要调用webservice接口,返回的为一个list集合内容,从webservice调用接口返回的为一个string的io流, 在调用接口的地 ...
- java集合_collection子接口 list的特有方法,ArrayList类体现
/* Collection |--List:元素是有序的,元素可以重复.因为该集合体系有索引. |--ArrayList:底层的数据结构使用的是数组结构.特点:查询速度很快.但是增删稍慢.线程不同步. ...
- java 15 -7 ListIterator 的特有方法
列表迭代器: ListIterator listIterator():List集合特有的迭代器 该迭代器继承了Iterator迭代器,所以,就可以直接使用hasNext()和next()方法. 特有 ...
- 《Java虚拟机原理图解》1.5、 class文件中的方法表集合--method方法在class文件中是怎样组织的
0. 前言 了解JVM虚拟机原理是每一个Java程序员修炼的必经之路.但是由于JVM虚拟机中有很多的东西讲述的比较宽泛,在当前接触到的关于JVM虚拟机原理的教程或者博客中,绝大部分都是充斥的文字性的描 ...
- Java进阶(二十四)Java List集合add与set方法原理简介
Java List集合add与set方法原理简介 add方法 add方法用于向集合列表中添加对象. 语法1 用于在列表的尾部插入指定元素.如果List集合对象由于调用add方法而发生更改,则返回 tr ...
随机推荐
- 如何针对已经安装好的Apache/PHP/Mysql/Nginx程序查看他们的编译参数
我们经常要对我们已经安装好的程序进行查看他当时的一些编译参数,特别是针对要安装多台服务器来说,而且要保证其他服务器上的软件版本和安装参数必须一致时,这种查看就是很有必要的了.具体查看各程序的编译参数命 ...
- @synthesize和@dynamic
@synthesize 除非开发人员已经做了,否则由编译器自动生成getter/setter方法.当开发人员自定义存或取方法时,自定义会屏蔽自动生成该方法. @dynamic 告诉编译器,不自动生成g ...
- springmvc的jdbcTemplate 插入 返回主键
public int insertCustomer(final Customer customer) { //TODO. final String sql = " ...
- java实现——006重建二叉树
public class T006 { public static void main(String[] args){ int pre[] = {1,2,4,7,3,5,6,8}; int in[] ...
- Treap初步
模板题 bzoj3224: Tyvj 1728 普通平衡树 #include <bits/stdc++.h> #define rep(i, a, b) for (int i = a; i ...
- 【uoj57】 WC2013—平面图
http://uoj.ac/problem/57 (题目链接) 题意 给出二位平面上n个点,点之间有一些连线,连线不在顶点之外的地方相交,将平面分为若干个区域.给出一些询问点对,问从这个点所在的区域走 ...
- CSS中怎么让DIV居中
CSS 如何使DIV层水平居中 今天用CSS碰到个很棘手的问题,DIV本身没有定义自己居中的属性, 网上很多的方法都是介绍用上级的text-align: center然后嵌套一层DIV来解决问题. 可 ...
- React Native 之 搭建开发环境
现在只能在MAC系统上安装. 1. 首先,HomeBrew 这是一个包管理库,用来下载其它工具. 打开网站:brew.sh 网页有个命令 /usr/bin/ruby -e "$(curl - ...
- 14.TCP的坚持定时器和保活定时器
一.坚持定时器 1.坚持定时器的由来 TCP通过让接收方指明希望从发送方接受的窗口大小来进行流量控制.设置窗口大小为0可以组织发送方传送数据,直至窗口变为非0为止. ...
- 一个a::before的写法
#key_table table tr td a::before{//这是个a前面的蓝色小圆点 background: #48A7D9; content: "";//这 ...