List 集合: 被比较的对象要重写equals()方法, 调用List中contains()方法,就是用equals()方法比较的.
List 集合 (允许重复元素,允许空值)
2 HashSet集合(不允许重复元素,允许空值): 被比较的对象要重写hashCode()方法和重写equals()方法, 两个都要.
3 TreeSet集合.(不允许重复元素):
方法一:被比较的对象(如学生类)实现Comparable接口,重写CompareTo()方法.--(不允许空值)
方法二:TreeSet的构造方法,传入Comparator接口的实现类,他是重写了compare()方法.--(允许空值)
4 HashMap集合: 与HashSet情况一样.
5 TreeMap集合: 与TreeSet情况一样.
6 顺便说一下, 对List排序可用Collections类的sort()方法.要用到Comparable或Comparator接口.
===========================================================
list:arraylist,vector,linkedlist,其中vetctor线程同步,linkedlist插删
基本上list都是基于array的;里面的元素都可以重复;
set:hashset,treeset;set不能够重复,set是基于map的;treeset是排序的
list和set是继承collection接口的,map不是
map:hashtable,hashmap,treemap;hashtable是线程同步的,map的key不能够重复,value可以;treemap是排序的
另外,没记错的话,list,set,map都是可以使用collections.sort()排序的 |