String s1 = "a";//"a"会被加载到常量池里,s1引用常量池里的"a"
String s2 = "b";//"b"会被加载到常量池里,s2引用常量池里的"b"
String s3 = s1 + s2;//底层拼接时相当于执行了new StringBuilder().append("a").append("b").toString() 而toString()里面则调用了return new String(xxx),我们知道new关键字创建的对象都在堆里面,所以s3指向了堆里面的一个String对象。
System.out.print("ab"==s3);//由于"ab"在常量池里,而s3的值在堆里面,所以比较结果是false
String s4 = "a" + "b";//这个不同于s3,是两个字符串常量拼接,结果是确定的,所以在编译期间就会直接优化为"ab",所以还在常量池里
System.out.print("ab"==s4);//结果为true
【jvm】字符串拼接的底层原理
于 2022-01-29 12:31:00 首次发布