java各常用集合类是否接受null值

本文深入探讨了Java集合框架中TreeSet和LinkedHashSet的特点与应用场景,对比了不同集合类如ArrayList、LinkedList、HashSet等处理重复数据及排序的能力,并解析了TreeSet如何通过红黑树结构实现元素的自然排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    TreeMap、TreeSet两个类在加入第二个元素时,会调用Comparator比较器比较先后加入的元素是否重复(TreeMap比较的是Key值)。所以当加入第一个元素时,即使第一个元素是null,也不会报错,因为此时不会调用比较器,再次加入元素则报错。

      已测试的其他集合类HashSet / HashMap / ArrayList / LinkedList均可接受null值。

问题:现在有一批数据,要求不能重复存储元素,而且要排序。ArrayList 、 LinkedList不能去除重复数据。HashSet可以去除重复,但是是无序。

所以这时候就要使用TreeSet、LinkedHashSet。一般情况下使用linkedHashSet。TreeSet是红黑树的结构,linkedHashSet是链表结构。

---| Itreable      接口 实现该接口可以使用增强for循环  
                ---| Collection     描述所有集合共性的接口  
                    ---| List接口     有序,可以重复,有角标的集合  
                            ---| ArrayList     
                            ---|  LinkedList  
                    ---| Set接口      无序,不可以重复的集合  
                            ---| HashSet  线程不安全,存取速度快。底层是以hash表实现的。  
                            ---| TreeSet  红-黑树的数据结构,默认对元素进行自然排序(String)。如果在比较的时候两个对象返回值为0,那么元素重复。  

 

转载于:https://my.oschina.net/u/588379/blog/1814209

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值