==判断的是两个对象的引用地址是否相等,也就是判断是否为同一个对象
1、通过String str1 = new String("a")直接申明一个String对象是不检查字符串池的,也不会把对象放到池中
2、String str2 = "a" 通过直接量进行赋值,Java为了避免在系统中产生大量的String对象,于是设计了字符串池,创建一个字符串时首先检查池中有字面值相等的字符串,如果有则不在创建,直接返回池中对象的引用,若没有,则创建,饭后放到池中,并返回对象的引用。
str2 == str1.intern(); //true
通过intern检查当前对象池中是否有字面值相等的引用对象,如果找到则返回池中的引用对象,如果没有则放置到池中,并返回当前对象
java在编译器已经决定了在JVM的字符串池,垃圾回收器是不会对它进行回收的
replaceAll("$中国$" , "$") --> Error
replaceAll传递的第一个参数是正则表达式,符合正则表达式的字符串才会被替换,因此在有特殊字符时可以使用replace替换
replace("$中国$" , "$") ; --> 中国
拼接字符串
1、在+表达式中,String字符串具有最高优先级,Java的运算顺序是从左到右,只要碰到String字符串,则所有的数据都会转换成String类型进行拼接,如果是原始数据则直接拼接,如果是对象则调用toString方法的返回值然后拼接
2、每次concat操作都会新创建一个String对象
3、StringBuffer/StringBuilder.append
版本是向下兼容的,只是他们包含的汉字数量不同而已
GB2312是中文字符集V1.0版
GBK是中文字符集V2.0版
GB18030是中文字符集V3.0版
如果要实现对中文排序,而排序不是一个关键算法,Collator可以满足大部分需求,否则需要使用pinyin4j等开源项目