如何确保Java 10+中Collectors.toUnmodifiableList()生成流结果的不可变性?
- 内容介绍
- 文章标签
- 相关推荐
本文共计813个文字,预计阅读时间需要4分钟。
相关专题:
从 java 10 开始,collectors.tounmodifiablelist() 返回的确实是真正不可变的 list —— 它不是“包装视图”,而是底层数据被封装、无反射绕过可能的只读集合。但“绝对只读”的前提是你正确使用它,且不引入其他可变引用。
核心保障:它返回的是 java.util.ImmutableCollections.ListN
Java 10+ 的 toUnmodifiableList() 不再基于 Collections.unmodifiableList()(该方法只是加了运行时检查的包装器),而是直接构造 JVM 内置的不可变实现类(如 ListN)。这个类:
- 内部数组是
private final,且不提供任何修改接口 - 所有 mutator 方法(
add、set、clear等)都直接抛UnsupportedOperationException - 序列化后反序列化仍是同一不可变类型,不会退化为可变副本
- 无法通过反射修改(JVM 层面对
ImmutableCollections类型做了保护,字段不可设值)
关键使用前提:避免泄露原始可变引用
不可变性只作用于你拿到的 List 实例本身。
本文共计813个文字,预计阅读时间需要4分钟。
相关专题:
从 java 10 开始,collectors.tounmodifiablelist() 返回的确实是真正不可变的 list —— 它不是“包装视图”,而是底层数据被封装、无反射绕过可能的只读集合。但“绝对只读”的前提是你正确使用它,且不引入其他可变引用。
核心保障:它返回的是 java.util.ImmutableCollections.ListN
Java 10+ 的 toUnmodifiableList() 不再基于 Collections.unmodifiableList()(该方法只是加了运行时检查的包装器),而是直接构造 JVM 内置的不可变实现类(如 ListN)。这个类:
- 内部数组是
private final,且不提供任何修改接口 - 所有 mutator 方法(
add、set、clear等)都直接抛UnsupportedOperationException - 序列化后反序列化仍是同一不可变类型,不会退化为可变副本
- 无法通过反射修改(JVM 层面对
ImmutableCollections类型做了保护,字段不可设值)
关键使用前提:避免泄露原始可变引用
不可变性只作用于你拿到的 List 实例本身。

