class StringEqualTest {
public static void main(String[] args) {
String s1 = "Programming"; //在字符串常量池存储"Programming"并返回引用值
String s2 = new String("Programming"); //在堆创建字符串"Programming"
String s3 = "Program"; //在字符串常量池存储"Program"并返回引用值
String s4 = "ming"; //在字符串常量池存储"ming"并返回引用值
String s5 = "Program" + "ming"; //编译器优化 可以通过反编译 StringEqualTest.class文件看到 String s5 = "Programming"; 这个优化技巧叫做常量折叠
String s6 = s3 + s4; // 字符串'+'拼接字符串实际上是创建一个stringbuild对象然后调用append方法最后tostring转化成字符串
System.out.println(s1 == s2); //false s1的引用值是指向字符串常量池 s2的引用值是指向堆 所以不是同一个
System.out.println(s1 == s5); //true //s5被常量折叠后的创建过程实际上是 String s5 = "Programming"; 字符串引号创建对象是如果常量池有就返回常量池的引用值 没有就在常量池创建字符串并返回引用值
System.out.println(s1 == s6); //false //s1是常量池里的引用 s6是通过stringbuilder创建以及append拼接后tostring生成的 是在堆上的对象 所以不是同一个
System.out.println(s1 == s6.intern()); //true //intern函数返回字符串的常量池引用 s1是常量池里"Programming"的引用 所以是同一个
System.out.println(s2 == s2.intern()); //false //s2是在堆上的引用 s2.intern()返回的是"Programming"在常量池上的引用
}
}
关于常量池和堆的情况
最新推荐文章于 2024-06-24 10:07:06 发布