字符串的一系列操作是比较基础但是又很常用的方法,很多逻辑处理都在这里,String类里面的方法也都很好用,嘿嘿,比较、连接、截取。。。当年刚毕业面试的时候,还被考过比较的源码,嘻嘻,说来真是印象深刻。
我最常用的是比较,获取一个布尔值来控制逻辑,其中“==”和equals方法一直很方便,最近有新学到一个intern(字符串驻留方法)。
关于“==”和equals的区别,最大就是很多继承自object的类自己重写了这个方法,按照本类特性对它进行了优化,就以String为例:
String str1 = "abc";
boolean ans1 = (str1 == "abc");
boolean ans2 = (str1.equals("abc"));
System.out.println("ans1 ------>"+ans1);
System.out.println("ans2 ------>"+ans2);
String str2 = new String("abc");
boolean ans3 = (str2 == "abc");
boolean ans4 = (str1 == str2);
boolean ans5 = (str2.equals("abc"));
boolean ans6 = (str1.equals(str2));
System.out.println("ans3 ------>"+ans3);
System.out.println("ans4 ------>"+ans4);
System.out.println("ans5 ------>"+ans5);
System.out.println("ans6 ------>"+ans6);
<pre name="code" class="java">ans1 ------>true
ans2 ------>true
ans3 ------>false
ans4 ------>false
ans5 ------>true
ans6 ------>true
因为 == 比较的是 地址,equals 在String类里被重写后,增加了:
if (anObject instanceof String) {
String anotherString = (String)anObject;
int n = count;
if (n == anotherString.count) {
char v1[] = value;
char v2[] = anotherString.value;
int i = offset;
int j = anotherString.offset;
while (n-- != 0) {
if (v1[i++] != v2[j++])
return false;
}
return true;
}
}
return false;
}
这么一段针对String的比较方式,结果就不一样了,true or false 就这么直接。
这里有一个问题,虽然equals方法很好,它的代价比较高,Android的性能一直是槽点,蚊子再小也是肉,如果==和equals一结果一样了呢。。。嘻嘻 这个就是我对intern方法的价值理解。
String str1 = "abc";
boolean ans1 = (str1 == "abc");
boolean ans2 = (str1.equals("abc"));
System.out.println("ans1 ------>"+ans1);
System.out.println("ans2 ------>"+ans2);
String str2 = new String("abc").intern;
boolean ans3 = (str2 == "abc");
boolean ans4 = (str1 == str2);
boolean ans5 = (str2.equals("abc"));
boolean ans6 = (str1.equals(str2));
System.out.println("ans3 ------>"+ans3);
System.out.println("ans4 ------>"+ans4);
System.out.println("ans5 ------>"+ans5);
System.out.println("ans6 ------>"+ans6);
修改了一行:String str2 = new String("abc").intern;
输出结果为:
ans1 ------>true
ans2 ------>true
ans3 ------>true
ans4 ------>true
ans5 ------>true
ans6 ------>true
嘻嘻,官方抄来的优点:1、执行非常快,再多线程中(仍然使用全局字符串池)几乎没有性能损失;2、节省内存,允许数据集更小,优化程序运行速度。
Ps: 1 、 在 1.7,1.8 之后才能用,
2、 尽量不要用在复用性低的字符串身上。