A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 黑马陈旭东 中级黑马   /  2012-5-25 21:34  /  1540 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

String类的讲解
(1)==,equals()
  String s1 = new String("Hello");
  Strint s2 = new String("Hello");
  String s3 = "Hello";
  String s4 = "Hello";
  sop(s1==s2);
  sop(s1==s3);
  sop(s1==s4);
  sop(s2==s4);
  sop(s3==s4);

求解在String 类里面,好像里面关系到一个变量池的问题!

目前纠结于在这个变量池到底是怎么回事!求理清思路!

2 个回复

正序浏览
String类的讲解
(1)==,equals()
  String s1 = new String("Hello");
  Strint s2 = new String("Hello");
  String s3 = "Hello";
  String s4 = "Hello";
  sop(s1==s2);   //false
  sop(s1==s3);   //false
  sop(s1==s4);   //false
  sop(s2==s4);   //false
  sop(s3==s4);   //true
JAVA虚拟机(JVM)中存在着一个字符串池,其中保存着很多String对象,并且可以被共享使用,因此它提高了效率。由于String类是final的,它的值一经创建就不可改变,因此我们不用担心String对象共享而带来程序的混乱。字符串池由String类维护。
代码被执行的时候,JAVA虚拟机首先在字符串池中查找是否已经存在了值为"abc"的这么一个对象,它的判断依据是Stringequals(Object obj)方法的返回值。如果有,则不再创建新的对象,直接返回已存在对象的引用;如果没有,则先创建这个对象,然后把它加入到字符串池中,再将它的引用返回。
s1与s2是new String()了两个对象了,所以不可能相等。


评分

参与人数 1技术分 +1 收起 理由
攻城狮 + 1 赞一个!

查看全部评分

回复 使用道具 举报
先看看java虚拟机将内存分配的几个空间:                                       
String str1 = new String("abc");  
String str2 = new String("abc");  
  
String str3 = "abc";  
String str4 = "abc";  
  
System.out.println(str1 == str2);  
System.out.println(str3 == str4);  
//输出结果:  
//false  
//true  
  
Integer a1 = new Integer(10);  
Integer a2 = new Integer(10);  
  
Integer a3 = 10;  
Integer a4 = 10;  
  
System.out.println(a1 == a2);  
System.out.println(a3 == a4);  
//输出结果  
//false  
//true  

      为什么会出现这种情况呢?我们先看看String str1 = new String("abc");创建了几个对象,首先它在栈中创建了一个叫str1的引用对象,然后又在堆中创建了一个“abc”
字符串对象。new的时候每次都是在堆中新建一个对象,而str3和str4是用等号赋值的,也就是它们的引用指向的是一个对象。在java中有个地方叫“变量池”,
像定义str3和str4的时候,java会在“变量池”中寻找是否有已经定义过的,如果有就将引用指向它,这样,当我们使用“==”比较时由于它们是同一个对象所以输出的是ture。
Integer的道理也是一样。

      那么我们再看下面一段代码:

Double d1 = new Double(2.0);  
Double d2 = new Double(2.0);  
  
Double d3 = 2.0;  
Double d4 = 2.0;  
  
System.out.println(d1 == d2);  
System.out.println(d3 == d4);  
//输出结果  
//false  
//false  

       同样的定义方法,为什么这里就输出false了?原因非常简单,在八个可以自动拆箱和装箱的基本变量中除了double和float以为都是有“变量池”的这种机制的,
而double和float没有,所以出现了上面代码的情况,无论怎么定义都是两个对象。

       上面的这个特性是JDK1.5以后才有的,1.5之前貌似没有这种特性,也不能直接将基本类型的变量封装成引用类型的。以上纯粹是个人总结的一点东西,如果有哪里
有问题还请大家指出。

评分

参与人数 1技术分 +1 收起 理由
攻城狮 + 1 赞一个!

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马