Java复合赋值运算符隐含窄化类型转换,如short s=1; s+=1;合法而s=s+1;报错;连续赋值a=b=c仅适用于已声明变量且右结合;==比较引用或原始值,对象应使用.equals();循环中String+=导致O(n²)性能问题。

Java中的赋值运算符有哪些技巧_复合赋值与连续赋值说明

Java里+=这类复合赋值不是简单缩写

它隐含类型转换,而且会悄悄改变计算顺序。比如short s = 1; s += 1;能编译通过,但s = s + 1;会报错:「possible loss of precision」。因为s + 1结果是int,而+=在赋值前自动做了窄化转换。

连续赋值a = b = c只在声明后有效

Java不支持像C那样在声明时链式初始化,比如int a = b = c = 0;直接编译失败:「cannot find symbol」。因为bc还没声明,=又不具备声明能力。

==比较引用还是值?这取决于类型

很多人以为==就是“等于”,其实它永远只比较内存地址(引用)或原始值(primitive),从不调用equals()。对象比较时,==几乎总是错的,除非你真要判断是不是同一个对象实例。

字符串拼接中+=的性能陷阱

在循环里用str += "x"看起来简洁,但每次都会新建String对象,时间复杂度是O(n²)。JVM虽有优化(比如把多个+=合并为StringBuilder),但只在**单条语句内**生效,跨循环就不行。

事情说清了就结束。最常被忽略的是复合赋值的隐式类型转换和字符串拼接中+=的上下文依赖性——它们看着像语法糖,实则行为边界很具体,一不留神就掉进语义坑里。
本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。