先看下面代码:
class test1
{
public static void main(string args[])
{
int a = 10;
int b = 10;
system.out.println("a is " + a);
system.out.println("b is " + b);
system.out.println("a==b is " + (a==b));//1 true
{
public static void main(string args[])
{
int a = 10;
int b = 10;
system.out.println("a is " + a);
system.out.println("b is " + b);
system.out.println("a==b is " + (a==b));//1 true
integer ia = new integer(10);
integer ib = new integer(10);
system.out.println("ia is " + ia);
system.out.println("ib is " + ib);
system.out.println("ia==ib is " + (ia==ib));//2 false
integer ib = new integer(10);
system.out.println("ia is " + ia);
system.out.println("ib is " + ib);
system.out.println("ia==ib is " + (ia==ib));//2 false
system.out.println("ia.equals(ib) is " + (ia.equals(ib)));//3 true
system.out.println("ib.equals(ia) is " + (ib.equals(ia)));//3 true
}
}
==和equals的用法总结如下:system.out.println("ib.equals(ia) is " + (ib.equals(ia)));//3 true
}
}
1. 用==测试两个primitive type是否完全相同,如代码中1处所示,或测试两个object refrencees 是否指向同一个对象,如代码中2处所示
2. 用equals比较两个对象的内容是否相同。如代码中3处所示。
需要注意的是上述比较都针对的是同一种类型的基本数据或对象,如果是不同类型之间的比较,看如下代码:
class test2
{
public static void main(string args[])
{
int a = 10;
float b = 10.0f;
system.out.println("a is " + a);
system.out.println("b is " + b);
system.out.println("a==b is " + (a==b));//1 true
{
public static void main(string args[])
{
int a = 10;
float b = 10.0f;
system.out.println("a is " + a);
system.out.println("b is " + b);
system.out.println("a==b is " + (a==b));//1 true
integer ia = new integer(10);
float fa = new float(10.0f);
system.out.println("ia is " + ia);
system.out.println("fa is " + fa);
system.out.println("ia.equals(fa) is " + (ia.equals(fa)));//2 false
system.out.println("fa.equals(ia) is " + (fa.equals(ia)));//2 false
}
}
1. 当程序比较基本类型数据 int a 和 float b 时,会将int 晋升为一个float ,此时10变成10.0,并认为二者是相等的,如代码中1处所示。float fa = new float(10.0f);
system.out.println("ia is " + ia);
system.out.println("fa is " + fa);
system.out.println("ia.equals(fa) is " + (ia.equals(fa)));//2 false
system.out.println("fa.equals(ia) is " + (fa.equals(ia)));//2 false
}
}
2. 两个隶属不同classes 的对象绝不会相等,除非你自己实现一个equals()方法。
注意上述代码中2处编译通得过,而且不会抛出任何异常,都返回false 。
------------------------------------------------------------------------------------
附:string对象的2种创建过程。
示例代码:
用字符串常量创建string型的对象时,在编译时,编译器向字符串常量缓冲区中添加该常量,
如果还有string s2 = "immutable";编译器会先判断缓冲区中是否有此常量,有的话就不会创建新的,而直接使用已有的字符串常量。这样s1 和 s2 就指向了同一个地址,两者的内容也都相同,即用== 和equals()方法比较都是true
附:string对象的2种创建过程。
示例代码:
public class stringinitial{
public static void main(string[] args){
string s1="hebing";
string s2="hebing";
string s3="he";
string s4=new string("hebing");
string s5=new string("hebing");
public static void main(string[] args){
string s1="hebing";
string s2="hebing";
string s3="he";
string s4=new string("hebing");
string s5=new string("hebing");
system.out.println("string:");
system.out.println("s12---"+s1.equals(s2)+"----"+(s1==s2));
system.out.println("s1:hebing---"+s1.equals("hebing")+"----"+(s1=="hebing"));
system.out.println("hebing:he-----"+s1.equals(s3));
system.out.println("s14----"+s1.equals(s4)+"----"+(s1==s4));
system.out.println("s4:hebing----"+s4.equals("hebing")+"----"+(s4=="hebing"));
system.out.println("s45----"+s4.equals(s5)+"----"+(s4==s5));
system.out.println("s12---"+s1.equals(s2)+"----"+(s1==s2));
system.out.println("s1:hebing---"+s1.equals("hebing")+"----"+(s1=="hebing"));
system.out.println("hebing:he-----"+s1.equals(s3));
system.out.println("s14----"+s1.equals(s4)+"----"+(s1==s4));
system.out.println("s4:hebing----"+s4.equals("hebing")+"----"+(s4=="hebing"));
system.out.println("s45----"+s4.equals(s5)+"----"+(s4==s5));
}
}
1. string s1 = "immutable";的创建过程}
用字符串常量创建string型的对象时,在编译时,编译器向字符串常量缓冲区中添加该常量,
如果还有string s2 = "immutable";编译器会先判断缓冲区中是否有此常量,有的话就不会创建新的,而直接使用已有的字符串常量。这样s1 和 s2 就指向了同一个地址,两者的内容也都相同,即用== 和equals()方法比较都是true
2. string s2 = new string("constructed");的创建过程
当这行代码被编译时,字符串常量"constructed"先被放进缓冲区中,到了运行时,new string()语句被执行,一个新的string实例被创建,并复制缓冲区中的字符串到新分配的内存空间中,最后新建的string对象被赋予s2,
显然,用new string()语句将导致额外的内存分配。至于常量缓冲区是存放在哪的,参见下面这篇讨论:
http://community.csdn.net/expert/topicview3.asp?id=4245026
当这行代码被编译时,字符串常量"constructed"先被放进缓冲区中,到了运行时,new string()语句被执行,一个新的string实例被创建,并复制缓冲区中的字符串到新分配的内存空间中,最后新建的string对象被赋予s2,
显然,用new string()语句将导致额外的内存分配。至于常量缓冲区是存放在哪的,参见下面这篇讨论:
http://community.csdn.net/expert/topicview3.asp?id=4245026
文章整理:西部数码--专业提供域名注册、虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!


