草庐IT

Immutability

全部标签

java - Java 字符串并非真正不可变的含义是什么?

背景在Java101中,我们被教导:AStringisimmutable.是的。好的。谢谢。然后我们进入Java102(或者Java201),我们发现:AStringisn'treallyimmutable:youcanchangeitusingreflection.啊。美好的。要么很可爱,要么非常反常,这取决于你的观点。到目前为止,这些东西已经discussedadinfinitum在StackOverflow和其他地方。在提出这个问题时,我认为这是理所当然的。我有兴趣问的是:问题OncewediscoverthataStringisn'treallyimmutable,whatar

java - 依赖注入(inject)、初始化后的不变性

我希望能够指定一个对象的成员变量在对象被“初始化”后是不可变的,这对我来说意味着在它被注入(inject)任何依赖项之后,并且已经执行了它所需要的任何其他初始化操作只能在DI之后执行。是否有满足我兴趣的语言-以这种方式形式化DI、初始化并支持不变性?使它们成为语言的一部分也许是愚蠢的;也许不吧。我不确定。今天我用Java编程,但我不能像我想的那样经常使用“final”,因为这些阶段发生在构造函数完成执行之后。关于如何使用Java获得我想要的东西的任何建议?我想我可以让我的对象实现一个基类,以便这些阶段在构造函数完成之前发生,或者使用方面来做同样的事情。想法?

java - 保护最终变量免受反射

我想设计一个类来逐步证明不变性。下面是一个简单的类publicclassImmutableWithoutMutator{privatefinalStringfirstName;privatefinalStringlastName;privatefinalintage;publicImmutableWithoutMutator(finalStringfirstName,finalStringlastName,finalintage){this.firstName=firstName;this.lastName=lastName;this.age=age;}@OverridepublicS

Java 不可变对象(immutable对象)

关闭。这个问题需要更多focused.Itisnotcurrentlyacceptinganswers.想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.Closed8yearsago.ImprovethisquestionIamlearningtheconceptofimmutability.Iunderstandthatimmutableobjectscannotchangetheirvaluesoncetheobjectiscreated.ButIdidn'tunderstandthefollowingusesofimmutableobjects.Th

java - java.lang.String 的哈希码真的被缓存了吗?

Strings1="String1";System.out.println(s1.hashCode());//returnanintegeri1Fieldfield=String.class.getDeclaredField("value");field.setAccessible(true);char[]value=(char[])field.get(s1);value[0]='J';value[1]='a';value[2]='v';value[3]='a';value[4]='1';System.out.println(s1.hashCode());//returnsameval

c# - 您期望不可变列表的不可变性有多深?

如果你有一个不可变列表,你希望它总是在你请求时返回对同一对象的引用,比如说list.get(0)我的问题是,您是否希望能够改变该对象并在下次从列表中获取它时反射(reflect)该改变? 最佳答案 这取决于上下文。在通用库中,我们应该假设list是不可变的。对列表中元素的更改将反射(reflect)给所有调用者,这是每次返回相同引用的直接结果。但是,如果这是一个专门的不可变树(或其他),并且被如此记录,那么您会期望列表中的项目本身是不可变的,这将成为一个有实际意义的问题。 关于c#-您期

java - 是否需要 Java 枚举类型的防御副本?

应该返回私有(private)引用类型的所谓“防御副本”。这是为了避免返回私有(private)字段的引用。我想知道私有(private)枚举类型是否有必要。我在某处读到枚举是不可变的引用类型,所以答案应该是“否”。是吗? 最佳答案 枚举不是本质上不可变的——但无论如何你都无法创建防御性副本,因为只有一组固定的实例可用——你有em>返回对现有实例之一的引用,而不是创建新实例。枚举通常应该无论如何都是不可变的,但为了抵消它们本质上不可变的说法:enumBadEnum{INSTANCE;privateintfoo;privateintg

java - 如何在带有日期字段的java中使类不可变?

我创建了一个带有日期字段的不可变类。我如何确保即使日期字段也是不可变的,因为即使您将日期字段设置为final,您以后仍然可以为其分配不同的值? 最佳答案 在您的getDate()方法中,返回一个newDate()实例,而不是相同的实例。publicDategetDate(){//Notcorrect.returnthis.date;//Thiswillmakeyourclassmutable.//Insteaduse,returnnewDate(this.date.getTime());//Thiswillmakesureyourd

java - 为不可变类实现 clone()

我正在开发一个类库。我有一个矩阵的抽象基类Matrix,它提供一些基本方法的实现。从Matrix派生的是不同类型矩阵的具体子类。我要求矩阵是可克隆的,所以Matrix实现了Cloneable接口(interface)。一些从Matrix派生的类是不可变的不可变类的克隆方法不返回对象的克隆,而是返回对象本身是否可以接受?用于澄清的一些(过于简化的)代码:abstractclassMatriximplementsCloneable{...}classImmutableMatrixextendsMatrix{ImmutableMatrixclone(){returnthis;}...}cla

java - 谷歌 Collection ( Guava 图书馆): ImmutableSet/List/Map and Filtering

假设您要构建一个ImmutableSet/List/Map对象的副本,但要过滤掉一些原始条目。一种实现方法如下:ImmutableList.copyOf(Iterables.filter(myObject,myObject.EQUALS));其中myObject.EQUALS是Iterables.filter()操作的谓词。我认为这是一个非常优雅且易于阅读的实现。然而,构建两个列表对象(第一个通过Iterables.filter(...)调用,第二个通过ImmutableList.copyOf(...))是非常低效的.有人知道更有效的方法吗?我想最好的办法是向ImmutableSet/