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)