ImmutableList.of() 是 Google Guava 库 提供的一个静态工厂方法,用于创建一个不可变的(immutable)列表。

ImmutableList.of()Google Guava 库 提供的一个静态工厂方法,用于创建一个不可变的(immutable)列表


✅ 简单理解:

复制代码

java

编辑

复制代码
List<String> list = ImmutableList.of("A", "B", "C");

这行代码会创建一个包含 "A""B""C"不可变列表


🔍 详细解释

1. ImmutableList 是什么?

  • 来自 Google Guava 库(com.google.common.collect.ImmutableList
  • 是一个 不可变集合(Immutable Collection)
  • 一旦创建,就不能再添加、删除、修改元素

类似于 Java 自带的 Collections.unmodifiableList(...),但更安全、更高效、API 更友好。


2. of() 方法的作用

ImmutableList.of(...) 是一组重载的静态方法,用于创建小规模的不可变列表。

常见用法:
复制代码

java

编辑

复制代码
// 创建空列表
ImmutableList<String> empty = ImmutableList.of();

// 创建单个元素
ImmutableList<String> one = ImmutableList.of("A");

// 创建多个元素(最多 5 个,Guava 提供了重载)
ImmutableList<String> three = ImmutableList.of("A", "B", "C");

// 创建更多元素(使用 varargs)
ImmutableList<Integer> many = ImmutableList.of(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

⚠️ 注意:of() 方法最多支持 5 个参数的重载,超过 5 个会使用 varargs 版本。


3. 不可变(Immutable)意味着什么?

一旦创建,就不能:

复制代码

java

编辑

复制代码
list.add("X");     // ❌ 抛出 UnsupportedOperationException
list.remove(0);    // ❌ 抛出 UnsupportedOperationException
list.set(0, "X");  // ❌ 抛出 UnsupportedOperationException

4. 为什么使用 ImmutableList.of()

优点 说明
线程安全 不可变,天然线程安全,无需同步
防止意外修改 避免被其他代码修改,提高健壮性
性能好 小列表有优化实现,比 new ArrayList<>() + add() 更快
可作为常量 适合定义常量列表
函数式编程友好 与 Stream、Optional 等配合良好

5. 实际例子

复制代码

java

编辑

复制代码
public class Constants {
    // 定义一个不可变的允许类型列表
    public static final ImmutableList<String> ALLOWED_TYPES = 
        ImmutableList.of("PDF", "DOCX", "XLSX", "PPTX");
}

外部代码无法修改这个列表,保证了安全性。


6. 和 Java 自带方法对比

方式 是否不可变 是否高效 是否可读
Arrays.asList("A", "B") ❌ 可通过 set() 修改元素
Collections.unmodifiableList(list) ❌ 需要先创建 list
List.of("A", "B") (Java 9+)
ImmutableList.of("A", "B") (Guava)

⚠️ 从 Java 9 开始,JDK 原生提供了 List.of(),功能类似 ImmutableList.of(),但 Guava 的 ImmutableList 功能更丰富(如 copyOf, builder() 等)。


✅ 总结

表达式 含义
ImmutableList.of("A", "B") 创建一个不可变列表,包含 A 和 B
不可变 不能增删改
适合 常量、配置、函数返回值、防止副作用

📦 依赖说明(Maven)

复制代码

xml

编辑

复制代码
<dependency>
    <groupId>com.google.guava</groupId>
    <artifactId>guava</artifactId>
    <version>32.1.3-jre</version>
</dependency>

✅ 所以你看到的:

复制代码

java

编辑

复制代码
ImmutableList<SessionChatRecordEntity> list

表示:一个不可变的 SessionChatRecordEntity 列表,通常用于传递一组不会被修改的数据。

相关推荐
火车叼位1 分钟前
脚本伪装:让 Python 与 Node.js 像原生 Shell 命令一样运行
运维·javascript·python
孤狼warrior12 分钟前
YOLO目标检测 一千字解析yolo最初的摸样 模型下载,数据集构建及模型训练代码
人工智能·python·深度学习·算法·yolo·目标检测·目标跟踪
devmoon19 分钟前
在 Polkadot Runtime 中添加多个 Pallet 实例实战指南
java·开发语言·数据库·web3·区块链·波卡
Katecat9966322 分钟前
YOLO11分割算法实现甲状腺超声病灶自动检测与定位_DWR方法应用
python
Evand J22 分钟前
TDOA(到达时间差)的GDOP和CRLB计算的MATLAB例程,论文复现,附参考文献。GDOP:几何精度因子&CRLB:克拉美罗下界
开发语言·matlab·tdoa·crlb·gdop
野犬寒鸦22 分钟前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
云姜.26 分钟前
java抽象类和接口
java·开发语言
仙剑魔尊重楼33 分钟前
音乐制作电子软件FL Studio2025.2.4.5242中文版新功能介绍
windows·音频·录屏·音乐·fl studio
xyq202436 分钟前
Pandas 安装指南
开发语言
xixixin_1 小时前
【JavaScript 】从 || 到??:JavaScript 空值处理的最佳实践升级
开发语言·javascript·ecmascript