java中字符串恒等判断
String str1 = new String("hello");
String str2 = new String("hello");
System.out.println(str1==str2);
// false
1. 起因:字符串恒等判断
//String is reference type String str1 = new String("hello"); String str2 = new String("hello"); System.out.println(str1==str2); // false System.out.println(str1.equals(str2)); // true
在线学习视频分享:java在线学习
2. 关系操作符 “==”
要点:“==”只可以处理基本数据类型对应值的恒等判断,不适用引用数据类型(其值存的是地址)
public class Main { public static void main(String[] args) { int n=3; int m=3; // true System.out.println(n==m); String str = new String("hello"); String str1 = new String("hello"); String str2 = new String("hello"); // false System.out.println(str1==str2); str1 = str; str2 = str; // true System.out.println(str1==str2); } }
n==m结果为true,这个很容易理解,变量n和变量m存储的值都为3,肯定是相等的。而为什么str1和str2两次比较的结果不同?要理解这个其实只需要理解基本数据类型变量和非基本数据类型变量的区别。
Java中的8个基本数据类型
浮点型:float, double;整型:byte, short, int , long; 字符型: char; 布尔型: boolean。
对于这8种基本数据类型的变量,变量直接存储的是“值”,因此在用关系操作符==来进行比较时,比较的就是 “值” 本身。要注意浮点型和整型都是有符号类型的,而char是无符号类型的.
对于非基本数据类型的变量(引用类型),如String类型,引用类型的变量存储的并不是 “值”本身,而是与其关联的对象在内存中的地址。如,str1并不是直接存储的字符串"hello",而是该对象所对应的地址。
因此在用==对str1和str2进行第一次比较时,得到的结果是false。因为它们分别指向的是不同的对象,也就是说它们实际存储的内存地址不同。 而在第二次比较时,str1和str2同时指向了str指向的对象,那么得到的结果毫无疑问是true(地址相同)。
3. Object方法 “equals()”
equals方法是基类Object中的方法,因此对于所有的继承于Object的类都会有该方法。 在Object类中,equals方法是用来比较两个对象的引用是否相等,即是否指向同一个对象.
public class Main { public static void main(String[] args) { String str1 = new String("hello"); String str2 = new String("hello"); // true System.out.println(str1.equals(str2)); } }
String类对equals方法进行了重写,用来比较指向的字符串对象所存储的字符串是否相等。 其他的一些类诸如Double,Date,Integer等,都对equals方法进行了重写用来比较指向的对象所存储的内容是否相等。
小结:
对于==:如果作用于基本数据类型的变量,则直接比较其存储的 “值”是否相等; 如果作用于引用类型的变量,则比较的是所指向的对象的地址
对于equals方法:如果没有对equals方法进行重写,则比较的是引用类型的变量所指向的对象的地址; 诸如String、Date等类对equals方法进行了重写的话,比较的是所指向的对象的内容(equals方法不能作用于基本数据类型的变量)。
更多相关文章教程请访问:java入门