String s = new String(“hello”);和String s = “hello”;的区别?以及字符串是如何相加的?

本文详细探讨了Java中字符串对象创建的newString()与直接赋值的区别,重点讲解了'=='和equals()的使用场景,以及字符串连接的内存分配原理。通过实例展示了字符串相加时的不同行为,揭示了常量池和变量操作的差异。

思考:

String s = new String(“hello”)和String s = “hello”;的区别?
字符串比较之看程序写结果
字符串拼接之看程序写结果


经过分析我们给出代码:

public class StringDemo3 {
    public static void main(String[] args) {
        String s1 = new String("hello");
        String s2 = "hello";

        System.out.println(s1==s2);//false
        System.out.println(s1.equals(s2)); //true
    }
}

 运行结果:

false
true

Process finished with exit code 0


 打开原码:

public boolean equals(Object anObject) {
        if (this == anObject) {
            return true;
        }
        if (anObject instanceof String) {
            String anotherString = (String)anObject;
            int n = value.length;
            if (n == anotherString.value.length) {
                char v1[] = value;
                char v2[] = anotherString.value;
                int i = 
### Javanew String字面量字符串区别及内存管理 在Java中,字符串可以通过直接赋值(字面量)或使用`new`关键字创建。这两种方式在内存管理对象行为上有显著差异。 #### 字面量字符串的内存管理 当通过直接赋值创建字符串时(例如 `String str = "hello";`),Java会将字符串存储在**字符串常量池**中[^1]。如果常量池中已经存在相同的字符串,则不会创建新的对象,而是复用已有的字符串。这种方式提高了性能并节省了内存空间。 #### 使用`new`关键字创建字符串的内存管理 当使用`new`关键字创建字符串时(例如 `String str = new String("hello");`),即使字符串常量池中已经存在相同的字符串,也会在**堆内存**中创建一个新的字符串对象[^3]。这意味着`new`关键字总是会在堆上分配独立的空间,而不考虑字符串常量池中的内容。 #### 对象比较 - 如果两个字符串是通过字面量方式创建的,并且它们的值相同,则它们引用的是同一个对象,`==`运算符返回`true`[^4]。 - 如果一个字符串是通过`new`关键字创建的,即使它的值字面量字符串相同,它们也位于不同的内存区域(堆常量池),因此`==`运算符返回`false`[^4]。 #### 示例代码 以下代码展示了两者的区别: ```java public class StringComparison { public static void main(String[] args) { String str1 = "hello"; String str2 = "hello"; String str3 = new String("hello"); System.out.println(str1 == str2); // true,因为str1str2指向常量池中的同一个对象 System.out.println(str1 == str3); // false,因为str3在堆中创建了一个新的对象 System.out.println(str1.equals(str3)); // true,因为equals方法比较的是字符串的内容 } } ``` #### 字符串拼接的底层原理 当进行字符串拼接时,如果没有变量参,编译器会在编译阶段优化并复用字符串常量池中的字符串[^1]。然而,如果有变量参,则每一步拼接都会在堆内存中创建新的字符串对象,这可能会导致内存浪费。 #### 相关方法的影响 如`StringBuilder.toString()`方法所示,它通过`new String()`的方式返回一个字符串对象,该对象位于堆内存中,而不是字符串常量池中[^2]。类似地,任何对字符串的操作(如`concat`或`replace`)都不会修改原始字符串,而是生成一个新的字符串对象[^5]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liangzai2048

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值