1、字符串拼接操作
- 常量与常量的拼接结果在常量池,原理是编译期优化。String s1="a"+"b"+"c";
- 常量池中不会存在相同内容的常量。
- 只要其中有一个是变量,结果就在 堆 中。变量拼接的原理是StringBuilder。
- 如果拼接符号的前后出现了变量,则相当于在堆空间中new String(),具体的内容为拼接的结果。
- 如果拼接的结果调用intern()方法,则主动将常量池中还没有的字符串对象放入池中,并返回此对象地址。
- intern():判断字符串常量池中是否存在值,如果存在,则返回常量池中的值的地址。如果字符串常量池中不存在值,则在常量池中加载一份,并返回此对象的地址。
2、为什么字符串拼接的值不在常量池中?
- 因为字符串是不可变的,若要进行字符串拼接,必须创建一个新的字符串对象来存储拼接后的结果。由于在运行时需要动态创建新的对象,因此该字符串对象不会被保存在常量池中。只有在编译时已经确定的字符串常量才会被保存在常量池中,因为它们是可以在编译时就确定的,不需要在运动时动态创建。
- 字符串拼接操作通常会产生新的字符串对象,这个新的字符串对象通常不会被放入常量池中,而是放在堆内存中的一个新的内存位置。这个因为字符串是不可变的,所以为了避免在常量池中创建过多的字符串对象,Java虚拟机规范不会对字符串拼接进行优化。因此,每次进行字符串拼接操作时,都会创建一个新的字符串对象,即使两个字符串的值相同,也会产生新的对象。如果想让字符串拼接的值在常量池中,可以使用字符串常量拼接或者使用StringBuilder类的append方法。
javapackage string; import org.junit.Test; public class StringTest5 { @Test public void test1() { String s1 = "a" + "b" + "c"; String s2 = "abc"; System.out.println(s1 == s2);//true System.out.println(s1.equals(s2));//true } @Test public void test2() { String s1 = "javaEE"; String s2 = "hadoop"; String s3 = "javaEEhadoop"; String s4 = "javaEE" + "hadoop"; String s5 = s1 + "hadoop"; String s6 = "javaEE" + s2; String s7 = s1 + s2; System.out.println(s3 == s4);//true System.out.println(s3 == s5);//false System.out.println(s3 == s6);//false System.out.println(s3 == s7);//false System.out.println(s5 == s6);//false System.out.println(s5 == s7);//false System.out.println(s6 == s7);//false String s8 = s6.intern(); System.out.println(s3 == s8);//true } }
字符串拼接操作的面试题讲解
丁总学Java2023-08-22 10:23
相关推荐
小马爱打代码4 小时前
面试题:内存模型与垃圾回收深度解析cfm_29147 小时前
JVM底层源码深度解析:读写屏障(Read/Write Barrier)wuminyu8 小时前
Java世界中StringTable源码剖析醉颜凉9 小时前
Elasticsearch性能优化:JVM GC调优全攻略,彻底解决集群卡顿、吞吐量下降问题顺风尿一寸10 小时前
从 Java 到内核:探秘线程改名的完整路径lihao lihao12 小时前
linux线程南极企鹅1 天前
JVM-编译执行过程苏克贝塔1 天前
.NET开发之.net framework对比.net corecfm_29141 天前
JVM垃圾收集算法与收集器深度解析自律懒人1 天前
AI Agent 工作流编排实战:从单 Agent 到多 Agent,手搭一套能跑通的协作系统