Java基础知识

String,StringBuffer与StringBuilde

2017-08-19  本文已影响78人  黑石ZB

其实我们在追究这三个的区别,一般都是在研究如何进行内存优化,这三者基本上都是被一个"+"给关联着,以前编写代码我们常常不管三七二十一的,通过+号来对字符串进行拼接,但后来在查看底层代码中,发现编译器会把"+"操作符在编译的时候转换成new StringBuilder().append,这里因为编译器代码比较复杂,就不贴了
我们说String的+操作效率低于StringBuilder的append方法,其实都是根据Java中字符串连接运算符+的实现方式。本质上,就是将参与字符串连接运算的字符串对象,转换为StringBuilder对象,然后在调用append方法,完成字符串连接操作。所以本质上,String的+操作,就是StringBuilder的append操作。但是如果直接使用String,代码在运行时候,还需要进行一次对象类型转换,创建新的对象等等,既浪费运算资源,降低了运算效率,还占据了多余的内存空间。所以,我们在想,我们为什么不直接使用StringBuilder呢?避免每一次编译器都会创建StringBuilder对象,这就有了下面三个的区别

1.String(字符串常量)

public final class String
    implements java.io.Serializable, Comparable<String>, CharSequence {
}

2.StringBuffer(JDK1.0 字符串变量,Synchronized即线程安全)

  1. 如果要频繁对字符串内容进行修改,出于效率考虑最好使用StringBuffer,如果想转成String类型,可以调用StringBuffer的toString()方法。
  2. Java.lang.StringBuffer线程安全的可变字符序列。在任意时间点上它都包含某种特定的字符序列,但通过某些方法调用可以改变该序列的长度和内容。可将字符串缓冲区安全地用于多个线程。
  3. StringBuffer 上的主要操作是 append 和 insert 方法,可重载这些方法,以接受任意类型的数据。每个方法都能有效地将给定的数据转换成字符串,然后将该字符串的字符追加或插入到字符串缓冲区中。append 方法始终将这些字符添加到缓冲区的末端;而 insert 方法则在指定的点添加字符。例如,如果 z 引用一个当前内容是“start”的字符串缓冲区对象,则此方法调用 z.append("le") 会使字符串缓冲区包含“startle”,而 z.insert(4, "le") 将更改字符串缓冲区,使之包含“starlet”。

3.StringBuilder(JDK5.0 字符串变量,非线程安全)

  1. 在内部,StringBuilder对象被当作是一个包含字符序列的变长数组。
  2. java.lang.StringBuilder是一个可变的字符序列,是JDK5.0新增的。此类提供一个与 StringBuffer 兼容的 API,但不保证同步。该类被设计用作 StringBuffer 的一个简易替换,用在字符串缓冲区被单个线程使用的时候(这种情况很普遍)。

三者的使用策略(很重要)

     ArrayList<String> list = new ArrayList<>(); 
        String result = "";
        for (String str : list) {
            result = result + str;
        }

       // 使用StringBuilder
        StringBuilder sb = new StringBuilder();
        for (String str : list) {
            sb.append(str);
        }
        String result = sb.toString();

当出现上面的情况时,显然我们要采用第二种方法,因为第一种方法,每次循环都会创建一个String result用于保存结果,除此之外二者基本相同

上一篇下一篇

猜你喜欢

热点阅读