字符串拼接操作的面试题讲解

1、字符串拼接操作

  1. 常量与常量的拼接结果在常量池,原理是编译期优化。String s1="a"+"b"+"c";
  2. 常量池中不会存在相同内容的常量。
  3. 只要其中有一个是变量,结果就在 堆 中。变量拼接的原理是StringBuilder。
  4. 如果拼接符号的前后出现了变量,则相当于在堆空间中new String(),具体的内容为拼接的结果。
  5. 如果拼接的结果调用intern()方法,则主动将常量池中还没有的字符串对象放入池中,并返回此对象地址。
  6. intern():判断字符串常量池中是否存在值,如果存在,则返回常量池中的值的地址。如果字符串常量池中不存在值,则在常量池中加载一份,并返回此对象的地址。

2、为什么字符串拼接的值不在常量池中?

  • 因为字符串是不可变的,若要进行字符串拼接,必须创建一个新的字符串对象来存储拼接后的结果。由于在运行时需要动态创建新的对象,因此该字符串对象不会被保存在常量池中。只有在编译时已经确定的字符串常量才会被保存在常量池中,因为它们是可以在编译时就确定的,不需要在运动时动态创建。
  • 字符串拼接操作通常会产生新的字符串对象,这个新的字符串对象通常不会被放入常量池中,而是放在堆内存中的一个新的内存位置。这个因为字符串是不可变的,所以为了避免在常量池中创建过多的字符串对象,Java虚拟机规范不会对字符串拼接进行优化。因此,每次进行字符串拼接操作时,都会创建一个新的字符串对象,即使两个字符串的值相同,也会产生新的对象。如果想让字符串拼接的值在常量池中,可以使用字符串常量拼接或者使用StringBuilder类的append方法。
java 复制代码
package 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
    }
}
相关推荐
小马爱打代码4 小时前
面试题:内存模型与垃圾回收深度解析
jvm
cfm_29147 小时前
JVM底层源码深度解析:读写屏障(Read/Write Barrier)
jvm
wuminyu8 小时前
Java世界中StringTable源码剖析
java·linux·c语言·jvm·c++
醉颜凉9 小时前
Elasticsearch性能优化:JVM GC调优全攻略,彻底解决集群卡顿、吞吐量下降问题
jvm·elasticsearch·性能优化
顺风尿一寸10 小时前
从 Java 到内核:探秘线程改名的完整路径
jvm
lihao lihao12 小时前
linux线程
java·开发语言·jvm
南极企鹅1 天前
JVM-编译执行过程
jvm
苏克贝塔1 天前
.NET开发之.net framework对比.net core
jvm
cfm_29141 天前
JVM垃圾收集算法与收集器深度解析
jvm·测试工具·算法·性能优化
自律懒人1 天前
AI Agent 工作流编排实战:从单 Agent 到多 Agent,手搭一套能跑通的协作系统
jvm