开发工具:eclipse-jee-kepler-SR1-win32
原始代码:
public class StringTest {
public static void main(String[] args) {
String s1 = "a"+"b"+"c";
String s2 = new String("a")+new String("b")+new String("c");
String s3 = "a"+"b"+new String("c");
String s4 = new String("a")+"b"+"c";
}
}
反编译工具(jd-gui)查看生成的class文件:
public class StringTest
{
public static void main(String[] args)
{
String s1 = "abc";
String s2 = new String("a") + new String("b") + new String("c");
String s3 = "ab" + new String("c");
String s4 = new String("a") + "b" + "c";
}
}
百度了一下。
对于String s = new String("a")生成的对象数是两个应该没有问题。一个是堆中生成的"a"对象,一个是字符串常量池中的"a"。至于一个指向字符串"a"的引用对象s的这种说法我觉得应该是错的,对象的引用是在栈中存放,引用应该不是一个对象;如果这种说法成立,可以推导出只要使用new关键字创建对象,都是创建了2个对象,这明显不合理!
String s = "a" + "b" +"c" 就这种写法,就我贴出的代码可以发现。编译编译时进行了优化,最后是String s = "abc"。String s = "a" + "b" +"c"这种写法最后其实只生成了一个对象,而不是"a","b","c","ab","abc"五个对象.其他组合情况也可以对照着看一下!
至于上述代码时候会应为jvm不同而导致编译后的结果不同,我还没能研究到那里去,如有高手希望能告知一下!