- string
public final class String
implements java.io.Serializable, Comparable<String>, CharSequence {
/** The value is used for character storage. */
private final char value[];
从这里可以看出,string是明显的immutable类,被修饰为final class,而且方法都被final修饰,所以拼接,剪裁等方法都new新的string。
为了避免大量的string被创建,其运行机制是:创建一个字符串时,首先检查池中是否有值相同的字符串对象,如果有则不需要创建直接从池中刚查找到的对象引用;如果没有则新建字符串对象,返回对象引用,并且将新创建的对象放入池中。但是,通过new方法创建的String对象是不检查字符串池的,而是直接在堆区或栈区创建一个新的对象,也不会把对象放入池中。上述原则只适用于通过直接量给String对象引用赋值的情况。
举例:String str1 = “123”; //通过直接量赋值方式,放入字符串常量池
String str2 = new String(“123”);//通过new方式赋值方式,不放入字符串常量池
注意:String提供了intern()方法。调用该方法时,如果常量池中包括了一个等于此String对象的字符串(由equals方法确定),则返回池中的字符串。否则,将此String对象添加到池中,并且返回此池中对象的引用。
2.stringBuffer
3.stringBuilder
stringBuffer和stringBuilder都继承了AbstractStringBuilder,提供了几乎一样方法。
abstract class AbstractStringBuilder implements Appendable, CharSequence {
/**
* The value is used for character storage.
*/
char[] value;
可以看出这个地方,不是用final修饰的,所以添加,等方法时不会new 对象。
但是,stringBuffer和StringBuilder是有不同的,StringBuffer所有方法都是被synchronized修饰的
@Override
public synchronized int length() {
return count;
}
@Override
public synchronized int capacity() {
return value.length;
}
@Override
public synchronized void ensureCapacity(int minimumCapacity) {
super.ensureCapacity(minimumCapacity);
}
也就是说stringBuffer是线程安全的,但安全的代价是,性能的降低。