一、List:、有顺序以线性方式存储,可以存放重复对象
线程安全方法:List list = Collections.synchronizedList(new LinkedList(...));
LinkedList:双向链表实现存储 索引数据慢插入数度较快 线程不安全(比安全性能好)
ArrayList:数组方式存储数据 索引数据快插入数据慢 线程不安全
Vector:数组方式存储数据 索引数据快插入数据慢 线程安全
Stack:继承自Vector,实现一个后进先出的堆栈
ArrayList:
import java.util.ArrayList; import java.util.List; public class Main { public static void main(String[] args) { List books = new ArrayList(); //向books集合中添加三个元素 books.add(new String("11111111111")); books.add(new String("22222222222")); books.add(new String("33333333333")); System.out.println(books); //将新字符串对象插入在第二个位置 books.add(1 , new String("44444444444")); for (int i = 0 ; i < books.size() ; i++ ) { System.out.println(books.get(i)); } //删除第三个元素 books.remove(2); System.out.println(books); //判断指定元素在List集合中位置:输出1,表明位于第二位 System.out.println(books.indexOf(new String("44444444444"))); //① //将第二个元素替换成新的字符串对象 books.set(1, new String("LittleHann")); System.out.println(books); //将books集合的第二个元素(包括) //到第三个元素(不包括)截取成子集合 System.out.println(books.subList(1 , 2)); } }
Result:
[11111111111, 22222222222, 33333333333] 11111111111 44444444444 22222222222 33333333333 [11111111111, 44444444444, 33333333333] 1 [11111111111, LittleHann, 33333333333] [LittleHann]