集合和不可变集合之间是什么关系

问题描述

我正在研究Java Collections FrameWork。
我在理解集合的层次结构时遇到了麻烦。

由于ArrayList实现了List接口,因此我们可以使用

List<String> list = new ArrayList();

但是,在

List<String> names = List.of("Larry","Kenny","Sabrina");

List.of()方法返回 ImmutableCollections.List12
我从未在Collection层次结构中听说过该类,并且发现它没有实现List接口(然后将其强制转换为List?)

此外,我认为我无法将ImmutalbeList创建为

List<String> names = new ImmutableList("Larry","Sabrina");

我对Kotlin知之甚少,在可变和不可变之间存在一个等级。但是我在Java中找不到它们之间的任何连接。
这是怎么回事?

解决方法

不可变收藏与普通收藏相同,但创建后无法修改(即只读)。您不能添加,删除或更新项目,如果尝试则抛出 unsupportetOperationException
您无法通过new ImmutableList()实例化ImmutableList,因为它是一个抽象类。您可以使用ImmutableList.of()方法获取免疫列表。
如果您想进一步了解immutableList,请参阅Geeksforgeeks - ImmutableList in java

,

为了彻底分析为什么会发生这种情况,让我们从不变性的定义开始:

'如果对象的状态在构造后无法更改,则认为该对象是不可变的。对不可变对象的最大依赖被广泛认为是创建简单,可靠代码的合理策略。

我们还可以确认,当我们查看Java中一个众所周知的类时,我们无法更改状态。字符串类。

public class Main {
public static void main(String[] args) {
    String hello = "hello";
    hello.concat("world");
    System.out.println(hello);
}

}

如果我们应用concat方法,则不会更改对象状态,只会返回“ hello”。但是,如果我们将结果初始化为一个新变量,那么它将具有这样的适当结果

public class Main {
public static void main(String[] args) {
    String hello = "hello";
    String newHello = hello.concat("world");
    System.out.println(newHello);
}

}

这个问题是concat方法对我说谎。它说它将连接某些东西,但实际上不是因为字符串是不可变的。因此,由于不可变对象无法更改其状态,因此我们也不应拥有更改其状态的方法。

由于我们不能将这些方法用于不可变的类型,我们不能仅实现接口的一部分,因此我们需要创建另一个接口,该接口仅包含可以从列表中读取但不更改对象状态的方法,例如例如List.add()。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...