使用final修饰的第一个好处是安全;第二个好处是高效,以JVM中的字符串常量池来举例,如下两个变量:
String s1 = "java"; String s2 = "java";
只有字符串是不可变时,我们才能实现字符串常量池,字符串常量池可以为我们缓存字符串,提高程序的运行效率
因为String
类型是不可变的,所以在字符串拼接的时候如果使用String
的话性能会很低,因此我们就需要使用另一个数据类型StringBuffer
,它提供了append
和insert
方法可用于字符串的拼接,它使用synchronized
来保证线程安全,如下源码所示:
@Override public synchronized StringBuffer append(Object obj) { toStringCache = null; super.append(String.valueOf(obj)); return this; } @Override public synchronized StringBuffer append(String str) { toStringCache = null; super.append(str); return this; }
因为它使用了synchronized
来保证线程安全,所以性能不是很高,于是在JDK1.5就有了StringBuilder
,它同样提供了append
和insert
的拼接方法,但它没有使用synchronized
来修饰,因此在性能上要优于StringBuffer
,所以在非并发操作的环境下可使用StringBuilder
来进行字符串拼接.