关闭

java 集合类中的对象如何比较

标签: javacollectionshashmapequalslistvector
305人阅读 评论(0) 收藏 举报
分类:

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接口.

---------------------------


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()排序的

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:1060577次
    • 积分:8338
    • 等级:
    • 排名:第2469名
    • 原创:125篇
    • 转载:448篇
    • 译文:3篇
    • 评论:35条
    最新评论