public interface List<E>extends Collection<E>
有序的 collection(也称为序列),允许重复的元素。
常用实现类:
ArrayList:
底层使用的是数组结构,特点:查询速度快,增删操作较慢,而且线程不同步.
要保证同步,可以使用:List list = Collections.synchronizedList(new ArrayList());
进行包装,默认容量为10.
常用方法:add
,addAll
,remove
,indexOf
,subList
,contains
,isEmpty
…
1
|
List<String> list = new ArrayList<String>();
|
容易忽略的方法:trimToSize()
//修正容量大小,用多少,给多少,ensureCapacity(int minCapacity)
//预设大小
自定义ArrayList:
1
|
/**
|
LinkedList
使用双向链表实现存储,允许所有元素(包括 null)。非线程安全,要保证同步,可以使用List list = Collections.synchronizedList(new LinkedList());
进行包装,可以被当作堆栈和队列来使用。
Vector
也是一个有序集合,允许重复元素,并且线程安全.
Map m = Collections.synchronizedMap(new HashMap(...));
初始容量
和加载因子
(默认.75)提供对集合进行操作的一个包装器,实现对集合的查找、排序、替换、 线程安全化(将非同步的集合转换成同步的)等操作。常用方法:
Collections.max(list);//返回list中字典顺序最大的元素。
int index = Collections.binarySearch(list,”zz”);//二分查找,返回角标。必须是有序的
Collections.fill();//可以将list集合中的所有元素替换成指定元素。
Collections.repalceAll(list,”要被替换的”,”替换的值”);//可以将list集合中的指定元素替换成指定元素。 Collections.reverse(); 反转
Collections.reverseOrder(参数是比较器);//逆向反转排序。倒序。。
Collections.shuffle(list);//随机对list中的元素进行位置的置换。
synchronizedXXX(XXX);非同步集合转成同步集合的方法:
用于操作数组对象的工具类,里面都是静态方法。
Arrays.asList:可以从 Array 转换成 List。可以作为其他集合类型构造器的参数。
Arrays.binarySearch:在一个已排序的或者其中一段中快速查找。
Arrays.copyOf:如果你想扩大数组容量又不想改变它的内容的时候可以使用这个方法。
Arrays.copyOfRange:可以复制整个数组或其中的一部分。
Arrays.deepEquals、Arrays.deepHashCode:Arrays.equals/hashCode的高级版本,支持子数组的操作。
Arrays.equals:如果你想要比较两个数组是否相等,应该调用这个方法而不是数组对象中的 equals方法(数组对象中没有重写equals()方法,所以这个方法之比较引用而不比较内容)。
Arrays.fill:用一个给定的值填充整个数组或其中的一部分。
Arrays.hashCode:用来根据数组的内容计算其哈希值(数组对象的hashCode()不可用)。
Arrays.sort:对整个数组或者数组的一部分进行排序。也可以使用此方法用给定的比较器对对象数组进行排序。
Arrays.toString:打印数组的内容。
原文:http://www.cnblogs.com/admol/p/5127823.html