首页 > 代码库 > String的点点滴滴
String的点点滴滴
一、String 的 equals()到底比较的是什么?equals() 与 == 的区别?
当使用关系运算符==比较两个对象时,是比较两个对象使用的内存地址和内容是否相同,如果两个对象使用的是同一个内存地址,并且内容相同,则结果为true,否则结果为false
当使用对象的equals( )方法比较两个对象时,是比较两个对象的内容是否相同。而与对象的内存地址无关,如果两个对象的内容相同,则结果为true,否则结果为false
例如:
String str1 = new String("hello");
String str2 = new String("hello");
String str3 = str2;
图解:
代码:
1 public class CompareObjectDemo { 2 public static void main(String[] args) { 3 String str1 = new String("hello"); 4 String str2 = new String("hello"); 5 String str3 = str2; 6 //用==比较 7 System.out.println("str1 == str2的比较结果为:\n\t" + (str1 == str2)); 8 System.out.println("str2 == str3的比较结果为:\n\t" + (str2 == str3)); 9 //用equals比较10 System.out.println("str1.equals(str2)的比较结果为:\n\t" +str1.equals(str2));11 System.out.println("str2.equals(str3)的比较结果为:\n\t" +str2.equals(str3));12 }13 }
结果:
注意:在Java中,如果将同一个字符串常量赋值给多个字符串变量来创建字符串对象,则这些字符串对象具有相同的地址,因为同一个字符串常量在内存中的地址是不变的,所以多个对象共用同一个内存地址
又如:
String str1 = "hello";
String str2 = "hello";
String str3 = str2;
图解:
代码:
1 public class CompareObjectDemo { 2 public static void main(String[] args) { 3 String str1 = "hello"; 4 String str2 = "hello"; 5 String str3 =str2; 6 7 //用==比较 8 System.out.println("str1 == str2的比较结果为:\n\t" + (str1 == str2)); 9 System.out.println("str2 == str3的比较结果为:\n\t" + (str2 == str3));10 //用equals比较11 System.out.println("str1.equals(str2)的比较结果为:\n\t" +str1.equals(str2));12 System.out.println("str2.equals(str3)的比较结果为:\n\t" +str2.equals(str3));13 }14 }
结果为:
二、String、StringBuffer、StringBuilder 它们的不同之处
(1)效率: String < StringBuffer < StringBuilder .
为什么?有没有想过?
每次改变String 的值, 底层重新创建了一个新的String对象,如:String str = ""; Str +="xpw"; Str +="yuanmeng"; 前面对str 进行了两次叠加,也创建了两个String对象,并不是简单同一个String对象。所以,不断地改变、string的值,会不断地创建对象,这肯定要耗时;另外,创建对象,也需要占用一定的内存吧,而且StringBuffer和StringBuilder 每次改变String值,不会重新创建新的对象,可以采用append(str)改变str值。所以有时在程序调优时,有必要采用Stringbuffer 或者 StringBuilder进行替换。
那么,StringBuffer为什么效率上会比StringBuilder慢?读过源代码的同学,想必知道了吧,StringBuffer它是线性安全的,就是说它的底层相关方法有Synchronize修饰,在并发时,如果多个线程要访问共享变量,不能简单地同时访问,一旦有一个线程锁住当前对象,其它线程就必须等;而StringBuiler是非线性安全的,允许多个线程同时访问,所以在效率上,StringBuilder 》 StringBuffer。
(2)StringBuffer:线性安全
StringBuider:非线性安全
注意:在并发时,要使用StringBuffer比较好,非并发,考虑到效率问题,尽量使用StringBuilder
String的点点滴滴
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。