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 列表,通常用于传递一组不会被修改的数据。

相关推荐
ZYMFZ3 小时前
python面向对象
前端·数据库·python
滑水滑成滑头3 小时前
**发散创新:多智能体系统的探索与实践**随着人工智能技术的飞速发展,多智能体系统作为当今研究的热点领域,正受到越来越多关注
java·网络·人工智能·python
十五年专注C++开发3 小时前
QDarkStyleSheet: 一个Qt应用的暗色主题解决方案
开发语言·c++·qt·qss
2401_841495643 小时前
【数据结构】最长的最短路径的求解
java·数据结构·c++·python·算法·最短路径·图搜索
麦麦鸡腿堡3 小时前
Java的代码块介绍与快速入门
java·开发语言
小龙报3 小时前
《算法每日一题(1)--- 连续因子》
c语言·开发语言·c++·windows·git·算法·visual studio
流浪大叔3 小时前
Python下载实战技巧的技术文章大纲
开发语言·python
祁同伟.3 小时前
【C++】异常
开发语言·c++