作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬
学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
Java 9 开始引入不可变集合,我们通过 of() 即可创建一个不可变集合(详情见:Java 9 新特性—新增只读集合和工厂方法)。但是有时候我们需要利用现有集合来创建一个不可变副本,然而 Java 9 并没有提供该方法,所以 Java10 对其进行了增强。
Java 10 新增 copyOf() 用于创建现有集合的不可变副本。分为以下两种情况:
- 如果原集合已经是不可变的,那么则返回原集合,
- 如果元集合不是不可变的,那么则创建一个新的对象。
如下:
@Test
public void copyOfTest() {
var list1 = List.of("死磕 Java 新特性","死磕 Java 并发","死磕 Netty");
var copyList1 = List.copyOf(list1);
System.out.println(list1 == copyList1);
var list2 = Arrays.asList("死磕 Java 新特性","死磕 Java 并发","死磕 Netty");
var copyList2 = List.copyOf(list2);
System.out.println(list2 == copyList2);
}
执行结果:
true
false
List.copyOf(list1) 由于 list1 本身是不可变集合,所以就直接将 list1 返回了,所以 list1 == copyList1,而 list2 是可变的,所以需要新建一个不可变对象,所以 list2 != copyList2。
从 copyOf() 的源码中我们也可以看出:
static <E> List<E> listCopy(Collection<? extends E> coll) {
if (coll instanceof List12 || (coll instanceof ListN && ! ((ListN<?>)coll).allowNulls)) {
return (List<E>)coll;
} else {
return (List<E>)List.of(coll.toArray()); // implicit nullcheck of coll
}
}
638

被折叠的 条评论
为什么被折叠?



