TreeSet和HashSet

目录

 

TreeSet

1、特性

2、通过构造方法自定义排序规则

 3、通过包装达到线程安全

4、TreeSet 迭代

5、关于是否可以保存null 元素

HashSet

1、特性:

2、迭代异常同TreeSet

3、性能


TreeSet

介绍:避免重复元素以及对元素进行排序,非线程安全

1、特性

  • 元素唯一
  • 不保留插入顺序
  • 元素升序排序
  • 非线程安全

2、通过构造方法自定义排序规则

Set<String> treeSet = new TreeSet<>(Comparator.comparing(String::length));

 3、通过包装达到线程安全

Set<String> syncTreeSet = Collections.synchronizedSet(treeSet);

4、TreeSet 迭代

通过iterator迭代器,直接通过集合修改元素会抛出ConcurrentModificationException ,而通过迭代则不会

会抛异常

@Test(expected = ConcurrentModificationException.class)
public void whenModifyingTreeSetWhileIterating_shouldThrowException() {
    Set<String> treeSet = new TreeSet<>();
    treeSet.add("First");
    treeSet.add("Second");
    treeSet.add("Third");
    Iterator<String> itr = treeSet.iterator();
    while (itr.hasNext()) {
        itr.next();
        treeSet.remove("Second");
    }
}

不会抛异常

@Test
public void whenRemovingElementUsingIterator_shouldRemoveElement() {
 
    Set<String> treeSet = new TreeSet<>();
    treeSet.add("First");
    treeSet.add("Second");
    treeSet.add("Third");
    Iterator<String> itr = treeSet.iterator();
    while (itr.hasNext()) {
        String element = itr.next();
        if (element.equals("Second"))
           itr.remove();
    }
 
    assertEquals(2, treeSet.size());
}

5、关于是否可以保存null 元素

java7之前是可以的,后面则不可以

 

HashSet

1、特性:

  • 元素唯一性且允许null值
  • 由HashMap支持
  • 非线程安全

2、迭代异常同TreeSet

3、性能

HashSet的性能主要是受两个因素的影响,一个事初始化容量一个是加载因子

默认初始化容量为16,默认加载因子为0.75

如果初始容量太小会降低空间复杂性,但同样会增大hash的频率,增大开销

如果初始容量太大则会增加迭代成本和初始内存消耗

所以有个规则就是

1、对于大条目数据增大初始容量,则几乎不需要迭代

2、对于小条目数据减少初始容量, 降低迭代次数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

独步秋风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值