不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

可以采用的方式包括:
1、将类声明为final,这样就不能继承了
2、将所有成员声明为私有的,这样就不允许直接访问这些成员
3、对变量不提供set方法,将所有可变成员声明为final,这样只能赋值一次
4、通过构造器初始化所有成员,进行深度拷贝,在get方法中不返回对象本身,而是返回克隆对象,即对象的深度拷贝

final

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

final类不能被继承,参考String
final基本数据类型变量赋值后,在进行赋值,会在编译器报错
final引用类型变量赋值后,在进行指向其他对象,会在编译器报错,但是可以改变对象里面成员的变量。

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

Collections.unmodifiable、guava的 Immutable**

Collections.unmodifiable、guava的 Immutable** 分别创建不可变对象,并且对象的内部成员变量也不能修改

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

Collections.unmodifiable**

注意:这里map 不能声明为final
不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

执行结果:
不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

Collections.unmodifiable**原理:

1.重新赋值了一个不可变的UnmodifiableMap<>(m)对象
2.这个UnmodifiableMap 中,所有操作map的方法,都会抛出异常
不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

Collections 的unmodifiable**对象:

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

guava Immutable**

不可变对象 final、 Collections.unmodifiable、guava的 Immutable**

guava的 Immutable** 原理与Collections.unmodifiable** 类似

相关文章: