浏览 7861 次
锁定老帖子 主题:JAVA集合类中的对象如何比较(是否重复)
精华帖 (0) :: 良好帖 (0) :: 新手帖 (1) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-01-02
最后修改:2009-03-06
1 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接口. 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-01-02
学java的都应该知道这些基础知识吧
|
|
返回顶楼 | |
发表时间:2009-01-02
我写一下吧,记住八个就行了:
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()排序的 |
|
返回顶楼 | |