guava初探-学习目录
不可变集合(guava不可变集合不接受null)
优点
- 当对象被不可信的库调用时,不可变形式是安全的
- 不可变对象被多个线程调用时,不存在竞态条件问题
- 不可变集合不需要考虑变化,因此可以节省时间和空间。所有不可变的集合都比它们的可变形式有更好的内存利用率(分析和测试细节);
- 不可变对象因为有固定不变,可以作为常量来安全使用
为啥不是用java自带的Collections.unmodifiablexxx实现
- 笨重而且累赘:不能舒适地用在所有想做防御性拷贝的场景
- 不安全:要保证没人通过原集合的引用进行修改,返回的集合才是事实上不可变的
- 低效:包装过的集合仍然保有可变集合的开销,比如并发修改的检查、散列表的额外空间
例如: 我们在获取不可变集合后,原集合还是可以添加元素,
@Test
public void testJava() {
List<String> list = new ArrayList<String>();
list.add("zs");
list.add("ls");
list.add("ww");
List<String> unmodifiableList = Collections.unmodifiableList(list);
System.out.println(unmodifiableList);
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");
ImmutableList<String> immutableList = ImmutableList.copyOf(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);
}