【Java八股】String == 理解

1.下面的结果是false

String str = new String("aa");
String str1 = new String("aa");
System.out.println(str == str1);

new出来的对象都是在堆上分配对象,==此时比较的是内存地址,str和str1是指向两个不同不同的对象,返回为false

 

2.下面的结果是true

String s = "aa";
String s1 = "aa";
System.out.println(s == s1);

string不通过new的直接通过=赋值的方式等同于new对象,但是分配的内存区域不同,new是在堆上分配,而string的=赋值是在运行时的常量池中赋值,在常量池中赋值时,相同的字符串只分配一次,第二次赋值时只是将内存池中这个指向这个对象的引用返回

 

当运行这String s = "aa";句代码是,s这个引用先从常量池中查找是不是有“”aa“”这个字符串,现在常量池中还没有这个‘aa’的对象,就在常量池中新建一个对象,并将地址赋值给s这个引用,当运行String s1 = "aa";时,在常量池中找到了相同的字符串就直接将这个对象的引用

赋值给s1,所以这s,s1指向的是同一个对象,返回true

3.下面的结果返回时false

String str = new String("aa");

String s = "aa";

System.out.println(s == str);

虽然这两种赋值方式都是创建对象,但是在创建的内存区域不同,所以返回false。str是在堆上分配内存,而=是在运行时常量池中分配内存

 

4.下面的结果返回true

String str = new String("aa").intern();

String s = "aa";

System.out.println(s == str);

由于string的值类型是private final char value[];被定义final类型不可变得,如果存在重复new相同的大字符串,则会浪费很多空间,如果将这种比较大,经常使用的string

放在运行时常量池中放一份,则会比较省内存,同时在比较值时,直接用==,比使用equals方法要性能要好很多,因为equals是使用一个一个遍历char值来计较是否相同的

当执行String str = new String("aa").intern();这一句时可以看成两步,赋值如下:

String str = new String("aa");

str = str.intern();

当执行String str = new String("aa");句时在堆内存分配一个对象,并返回指向这个对象的引用str,如下图:

 

当执行str = str.intern();这句时,先在运行时常量池中查找是否有这个‘’aa‘’一样值得对象,因为还没有在常量池中赋值过‘aa’,所以在常量池中创建一个对象‘aa’,并将指向这个对象的引用赋值给str,此时的内存模型如下图:

 

当在执行String s = "aa";时,将在常量池中返回这个实例的引用,此时的内存模型如下图:

 

此时str和s指向了同一个内存区域的同一个对象的内存地址,所以返回true。
————————————————
版权声明:本文为CSDN博主「崖石」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/woshieer/article/details/84893927


__EOF__

本文作者blanset
本文链接https://www.cnblogs.com/blanset/p/16816903.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   求道之愚者  阅读(90)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示