文章目录
一、String
有关String的知识点大致如下
- String为final关键字修饰,所以无法被继承,且String不是Java的基本数据类型,同时因为String被final关键字修饰,所以String在Java中一经赋值不可变,因而适合在多线程环境下使用
- String常量池-当我们使用双引号创建一个字符串时,如下,JVM 首先在字符串池中寻找具有相同值的字符串。如果找到了,它将返回字符串池中的字符串对象的引用。否则,它会在字符串池中创建字符串对象并返回引用。JVM 通过在不同的线程中使用相同的字符串,节省了大量的内存。
例如:
String str1 = "ABC";
String str2 = "ABC";
str1和str2其实指向的是同一块内存空间
- 如果使用new运算符创建字符串,则会在堆中创建字符串
- 运算符 + 是为 String 重载的,我们可以用它来串联两个字符串。尽管在内部它使用 StringBuilder 来执行这个动作。
- 两个字符串只有在它们具有相同字符串的时候才相等,因为常量池的存在,所以推荐使用equals方法对字符串进行比较,equals() 方法区分大小写。如果您正在寻找不区分大小写的检查,您应该使用 equalsIgnoreCase() 方法。
- String的equals方法本质是基于字符串生成的哈希值进行比较
二、StringBuffer和StringBuilder
1.拼接字符串
由于 String 在 Java 中是不可变的,因此每当我们执行字符串拼接操作时,它都会生成一个新的 String 并丢弃旧的 String 以进行垃圾收集。
这些重复的操作会在堆中产生大量垃圾冗余。所以 Java 提供了 StringBuffer 和 StringBuilder 类,应该用于字符串操作。
2.StringBuffer和StringBuilder
StringBuffer 和 StringBuilder 是 Java 中的可变对象。
它们为字符串操作提供了 append、insert、delete 和 substring 方法。
二者对比
StringBuffer如何保证线程安全
相关方法使用synchronized关键字上锁
public synchronized StringBuffer append(Object obj) {
super.append(String.valueOf(obj));
return this;
}
public synchronized StringBuffer append(String str) {
super.append(str);
return this;
}
对比StringBuilder相关关键字
private StringBuilder append(StringBuilder sb) {
if (sb == null)
return append("null");
int len = sb.length();
int newcount = count + len;
if (newcount > value.length)
expandCapacity(newcount);
sb.getChars(0, len, value, count);
count = newcount;
return this;
}
总结
- 使用速度上,StringBuilder>StringBuffer>String
- 字符串运算符(+)内部使用StringBuilder