guava学习-不可变集合

guava初探-学习目录

不可变集合(guava不可变集合不接受null)

优点

  • 当对象被不可信的库调用时,不可变形式是安全的
  • 不可变对象被多个线程调用时,不存在竞态条件问题
  • 不可变集合不需要考虑变化,因此可以节省时间和空间。所有不可变的集合都比它们的可变形式有更好的内存利用率(分析和测试细节);
  • 不可变对象因为有固定不变,可以作为常量来安全使用

为啥不是用java自带的Collections.unmodifiablexxx实现

  1. 笨重而且累赘:不能舒适地用在所有想做防御性拷贝的场景
  2. 不安全:要保证没人通过原集合的引用进行修改,返回的集合才是事实上不可变的
  3. 低效:包装过的集合仍然保有可变集合的开销,比如并发修改的检查、散列表的额外空间
例如: 我们在获取不可变集合后,原集合还是可以添加元素,
    @Test
    public void testJava() {
        List<String> list = new ArrayList<String>();
        list.add("zs");
        list.add("ls");
        list.add("ww");

        //通过list创建一个不可变的unmodifiableList集合
        List<String> unmodifiableList = Collections.unmodifiableList(list);
        System.out.println(unmodifiableList);

        //向list添加元素
        list.add("mz");
        System.out.println("向list添加一个元素:" + list);
        System.out.println("向list添加元素之后的unmodifiableList:" + unmodifiableList);
    }

guava不可变集合的实现方式

copyOf 方法
    @Test
    public void testGuavaCopyOf() {
        List<String> list = new ArrayList<String>();
        list.add("zs");
        list.add("ls");
        list.add("ww");

        //通过list创建一个不可变的unmodifiableList集合
        ImmutableList<String> immutableList = ImmutableList.copyOf(list);

        //向list添加元素
        list.add("mz");
        System.out.println("向list添加一个元素:" + list);
        System.out.println("向list添加元素之后的immutableList:" + immutableList);
    }
of 方法
    @Test
    public void testGuavaOf(){
        ImmutableSet<String> of = ImmutableSet.of("zs", "ls", "ww", "mz");
        System.out.println(of);
    }
builder 方法
    @Test
    public void testGuavaBuilder() {
        List<String> buliderList = ImmutableList.<String>builder()
                .add("zs")
                .add("lis")
                .add("ww")
                .add("mz").build();
        System.out.println("buliderList" + buliderList);
    }

猜你喜欢

转载自blog.csdn.net/wolf2s/article/details/106801764