java之表达式陷阱

String str1 = "Hello Java的长度:10"; 

String str2 = "Hello Java的长度:10"; 
String str3 = "Hello Java的长度:"+"Hello Java".length; 
String str4 = "Hello "+"Java的长度:10"; 
System.out.print(str1 == str2);    输出:true 
System.out.print(str1 == str3);    输出:false 
System.out.print(str1 == str4);    输出:true 

通过以上例子可以得到。对于Java中字符直接量,JVM会使用一个字符串池来保存它们;一般情况下字符串池中的字符串对象不会被垃圾回收,当程序再次需要使用该字符串时,无需重新创建一个新的字符串,而是直接引用已有的字符串。通过表达式来创建字符串对象,如果这个字符串连接表达式的值可以在编译时确定下来。那么JVM会在编译时计算该字符串变量的值,并让它指向字符串池中对应的字符串。 
字符串也许以后永远不会在被用到,但这个字符串并不会被垃圾回收,因为它将一直存在于字符串池中---这是Java内存泄漏的原因之一。 
注:System.identityHashCode(str);可以得到某一个对象的唯一的hashcode值,这个indentityHashCode()的返回值与该类是否重写了hashcode()方法无关,只有当两个对象相同时,它们的值才会相同。 

建议String字符串用StringBuiler创建。 

         StringBuilder str = new StringBuilder("Hello "); 
         System.out.println(str); 
         System.out.println(System.identityHashCode(str)); 
         str.append("Java"); 
         System.out.println(str); 
         System.out.println(System.identityHashCode(str)); 
         str.append(", crazyit.org"); 
         System.out.println(str); 
         System.out.println(System.identityHashCode(str)); 

输出结果: 
Hello 
2046136590 
Hello Java 
2046136590 
Hello Java, crazyit.org 
2046136590 

复合赋值运算的陷阱: 
short sValue = 5; 
sValue = sValue - 2; 
编译通不过。因为sValue-2表达式的类型将自动提升为int类型,所以程序将一个int类型的值赋给short类型时导致编译错误。 
但是上述代码修改为 
short sValue = 5; 
sValue -= 2; 
则不会编译错误。 
复合赋值运算符含有自动强制类型转换。 
上述代码即为:sValue = (short) sValue - 2; 
存在的问题是:可能在强制转换过程中。存在高位截去,造成数据的损失。 
String 类型的+=运算符左边的变量只能是String类型,而不可能是String的父类型(如:Object 或者 CharSequence) 
 
 
原文地址:https://www.cnblogs.com/woniu4/p/5559817.html