您的位置:首页 > 编程语言 > Java开发

Java List集合知多少?

2016-05-16 23:50 1176 查看
List集合在开发中可谓是最经常使用的了,从第一次使用到“爱不释手”。有用的没用的都整理了一下。



1.基本概念

List:Collection集合的子接口,List是有序集合,允许元素重复,List中的元素都对应着一个整数型的序号,记载其在容器中的位置,可以根据序号存取容器中的元素。

2.常用方法

(1).添加功能

// 向滚动列表的末尾添加指定的项
void add(String item)
// 向滚动列表中索引指示的位置添加指定的项
void add(String item, int index)


List list = new ArrayList();
// 添加元素
list.add("A");
// 添加元素并指定位置
list.add(1, "B");
list.add(0, "C");
// 添加自定义对象
list.add(new User("--", 11));
System.out.println(list);// [C, A, B, User [name=--, age=11]]


(2).删除功能

// 从此滚动列表中移除指定位置处的项
void remove(int position)
// 从列表中移除项的第一次出现
void remove(String item)
// 从此列表中移除所有项
void removeAll()


List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("B");
System.out.println(list);// [A, B, C, B]
//根据index删除元素
list.remove(0);
System.out.println(list);// [B, C, B]
//根据元素对象删除元素
list.remove("B");
System.out.println(list);// [C, B]
//删除全部元素
list.removeAll(list);
System.out.println(list);// []


(3).获取功能

// 获取与指定索引关联的项
Object list.get(int index)
// 获取列表中的项
int list.size();


List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("B");
System.out.println(list.get(0));// A
System.out.println(list.get(3));// B
System.out.println(list.size());// 4


(4).修改功能

// 用指定元素替换列表中指定位置的元素
// E set(int index, E element)


List<String> list = new ArrayList<String>();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("B");
System.out.println(list);// [A, B, B]
// 替换位置index为2的元素
list.set(2, "C");
System.out.println(list);// [A, B, C]


(5).迭代器使用

图示:



通用迭代器:

//如果仍有元素可以迭代,则返回true
boolean hasNext()
//返回迭代的下一个元素
E next()
//从迭代器指向的collection中移除迭代器返回的最后一个元素
void remove()


List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("D");
// 普通迭代器
Iterator iterator = list.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());// ABCD
}
// 删除一个元素
iterator.remove();
System.out.println(list);// ABC


列表迭代器:

// 将指定的元素插入列表
void add(E e)
// 以正向遍历列表时,如果列表迭代器有多个元素,则返回true
boolean hasNext()
// 如果以逆向遍历列表,列表迭代器有多个元素,则返回true
boolean hasPrevious()
// 返回列表中的下一个元素
E next()
// 返回对next的后续调用所返回元素的索引
int nextIndex()
// 返回列表中的前一个元素
E previous()
// 返回对previous的后续调用所返回元素的索引
int previousIndex()
// 从列表中移除由next或previous返回的最后一个元素
void remove()
// 用指定元素替换next或previous返回的最后一个元素
void set(E e)


List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("D");
// 列表迭代器
ListIterator listIterator = list.listIterator();
while (listIterator.hasNext()) {
System.out.print(listIterator.next());// ABCD
}
while (listIterator.hasPrevious()) {
//返回列表中的前一个元素
System.out.println(listIterator.previous());// DCBA
}


注:使用previous()方法的时候,需要先向后遍历,才能逆向遍历输出。

并发修改异常:

// 并发修改异常
List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("D");

// java.util.ConcurrentModificationException
for (Object object : list) {
// 这里改变了集合 相对于改变了循环条件,所以有异常
list.remove(0);
}


注:使用迭代器如果有类似写法也会出现并发修改异常。

3.遍历集合

(1)使用获取方法

List list = new ArrayList();
// 添加
list.add("A");
// 添加元素并指定位置
list.add("B");
list.add("C");
list.add("D");

for (int i = 0; i < list.size(); i++) {
String str = (String) list.get(i);
System.out.print(" " + str);// A B C D
}


(2)使用迭代器

ListIterator iterator = list.listIterator();
while (iterator.hasNext()) {
String str = (String) iterator.next();
System.out.print(" " + str);// A B C D
}


(3)使用增强for

for (Object object : list) {
String str = (String) object;
System.out.print(" " + str);// A B C D
}


4.*主要实现类

(1)ArrayList:

是线性顺序存储的,是一种线性表,可以存储重复数据,可以看成动态数组。底层数据结构是数组,查询快,增删慢。线程不安全,效率高。

(2)LinkedList:

List接口的链接列表实现底层数据结构是链表,查询慢,增删快。线程不安全,效率高。

常用方法:

添加方法:
// 将指定元素插入此列表的开头
void addFirst(E e)
// 将指定元素添加到此列表的结尾
void addLast(E e)
删除方法:
// 移除并返回此列表的第一个元素
E removeFirst()
// 移除并返回此列表的最后一个元素
E removeLast()
获取方法:
// 返回此列表的第一个元素。
E getFirst()
// 返回此列表的最后一个元素
E getLast()


LinkedList<String> linkedList = new LinkedList<String>();
// 添加到集合最开头
linkedList.addFirst("A");
linkedList.add("B");
// 添加到集合最末尾
linkedList.addLast("C");
System.out.println(linkedList);// [A, B, C]

linkedList.removeFirst();
linkedList.removeLast();
System.out.println(linkedList);// [B]

System.out.println(linkedList.getFirst());// B
System.out.println(linkedList.getLast());// B


(3)Vector:

动态数组,可以根据需要动态伸缩。底层数据结构是数组,查询快,增删慢。线程安全,效率低。

常用方法:

添加方法:
// 将指定的组件添加到此向量的末尾,将其大小增加 1
void addElement(E obj)
删除方法:
// 从此向量中移除全部组件,并将其大小设置为零
void removeAllElements()
// 从此向量中移除变量的第一个(索引最小的)匹配项
boolean removeElement(Object obj)
// 删除指定索引处的组件
void removeElementAt(int index)
获取方法:
// 返回指定索引处的组件
E elementAt(int index)
// 返回此向量的组件的枚举
Enumeration<E> elements()
// 返回此向量的第一个组件
E firstElement()
// 返回此向量的最后一个组件
E lastElement()


Vector<String> vector = new Vector<String>();
//添加元素
vector.addElement("A");
vector.addElement("B");
vector.addElement("C");
vector.addElement("D");
System.out.println(vector);//[A, B, C, D]

//移除元素
vector.removeElementAt(0);
vector.removeElement("D");
System.out.println(vector);//[B, C]

System.out.println(vector.firstElement());//B
System.out.println(vector.lastElement());//C
// Enumeration类似于迭代器
Enumeration<String> element= vector.elements();
while (element.hasMoreElements()) {
System.out.print(" "+element.nextElement());// B C
}


注:更多方法查看API
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: