草庐IT

可变性

全部标签

java - 静态初始化的 unmodifiableCollection.get 是否保证不可变?

静态初始化的unmodifiableCollection.get是否保证不可变?对于:静态最终mapFOO=Collections.unmodifiableMap(newHashMap());多线程使用get方法能不出问题吗?即使无法添加/删除FOO中的项目,是什么阻止了get方法出于缓存目的操纵FOO的内部状态等。如果以任何方式修改内部状态,则FOO不能同时使用。如果是这样,java中真正的不可变集合在哪里? 最佳答案 给出具体的例子:staticfinalMapFOO=Collections.unmodifiableMap(ne

java - Logback MDC put() 可变对象

我正在使用Vaadin框架,它对拦截事件的支持很差,我无法知道session或UI何时被激活,所以我无法将它们的ID放入MDC。通常我会:publicvoidonSessionBegin(){MDC.put("session",VaadinSession.getCurrent().toString());//但是我没有这样的事件,所以我想://intheservletinitorwhereverMDC.put("session",newObject(){publicStringtoString(){VaadinSession.getCurrent().toString()};});//

java - 等价于 Java 中的 C++ 可变参数模板

我想用Java编写一个泛型类型安全的观察器。在C++中,我可以使用C++11中的可变参数模板轻松完成此操作,如下所示:classObserver{voidupdate(T...args);};现在,在java中,我能做的最好的事情是:classObserver{voidupdate(Targs);};现在,update不能像C++那样接受多个不同类型的参数。有人可以建议解决这个问题吗?提前致谢。 最佳答案 如果所有参数都扩展/实现T你可以说:classObserver{voidupdate(Listargs){}}

java - Java 中的不变性、协变性和逆变性

Javalessonongenerics带我去variance概念。这让我有些头疼,因为我找不到一个非常简单的演示来说明它是什么。我读了几本similarquestionsonstackoverflow,但我发现它们对于Java学习者来说太难理解了。其实问题在于泛型的解释需要理解方差,而方差概念的论证很大程度上依赖于对泛型的理解。我有一些希望阅读this,但最后我分享了C.R.的感受:Thetitleremindsmeofthedayslearninggeneralrelativity.–C.R.Dec22'13at7:34四道理论题让我很困惑,我找不到很好的简单解释。以我目前的部分理

java - 不可变链表的拆分器

这是不可变链表的经典实现:publicabstractclassListimplementsIterable{privatestaticfinalListNIL=newNil();publicabstractAhead();publicabstractListtail();publicListcons(Aa){returnnewCons(a,this);}publicstaticListnil(){returnNIL;}@OverridepublicIteratoriterator(){returnnewIterator(){privateListlist=List.this;@Ove

java - 使用修饰符创建不可变类的好方法(线程安全)

我有一个案例,当我想避免防御性副本时,对于可能仍然被修改但通常只是读取而不是写入的数据。所以,我想使用不可变对象(immutable对象),使用函数式修改器方法,这很常见(javalombok能够或多或少地自动完成)。我的处理方式如下:publicclassPerson{privateStringname,surname;publicPerson(Stringname,Stringsurname){....}//getters...//andinsteadofsetterspublicPersonwithName(Stringname){Personp=copy();//createa

Java 可变参数传递 lambda 和值

我试图在varag中结合lambda和简单值。publicstaticvoidLog(Stringformat,Object...args){finalObject[]fmt=newObject[args.length];for(inti=0;i"aaa",d=()->111;Log("%s%d%s%d","bbb",222,s,d);//OK,OUTPUT:bbb222aaa111Log("%s%d%s%d","bbb",222,()->"aaa",()->111);//COMPILEFAIL错误:方法Log不能应用于给定类型;所需字符串,对象[]找到:字符串,字符串,整数,()->

java - 不可变类型需要复制构造函数吗?

假设我有一个不可变的DecimalNumber类:publicfinalclassDecimalNumber{publicfinalStringstr;publicDecimalNumber(Stringstr){this.str=str;}publicDecimalNumber(DecimalNumbercopy){this(copy.str);}publicbooleanisZero(){...}publicDecimalNumberadd(DecimalNumberother){...}...}我决定像这样实现add:publicDecimalNumberadd(DecimalN

java - 如何用可变数量的十进制数字格式化 double

我正在执行一项任务,我在处理下面提到的负面情况时感到震惊如果值小于1,那么我想为其格式化(添加)4个小数点。例如,如果值为0.4567,那么我需要0.4567否则,如果该值大于1格式且只有2位数字。例如,如果值为444.9,那么我需要444.90上面提到的一切都工作正常,但遇到以下情况也就是说,如果值小于1并且以零结尾(0.1000,0.6000),打印0.2000是没有意义的,所以在这种情况下我希望输出仅为0.20下面是我的程序packagecom;importjava.text.DecimalFormat;publicclassTest{publicstaticvoidmain(S

java - 一种将可变数据结构声明为输出并实际返回不可变数据结构的方法

最近,我对这个问题进行了热烈的讨论。假设我在Java中创建了这个方法:publicSetgetRich(){returnImmutableSet....;}每当我在拉取请求中看到这一点时,我都会大喊并试图解释为什么它是错误的。通过这样做,我通过promise他们将获得Set误导了我的方法的消费者。这意味着他们可以删除或添加元素。javac会愉快地编译它,但会抛出RuntimeException。此外,它违反了“里氏替换原则”。就个人而言,我总是这样做:publicImmutableSetgetRich(){returnImmutableSet....;}这样一来,没人会搬起石头砸自己的