直接上代码吧:

package mm_test;

/**
 * @Function: TODO ADD FUNCTION. <br/>
 * @Date: 2016年4月14日 下午8:25:43
 *
 * @author zhangmengmeng01@baidu.com
 */
public class TerminationCondition {

    public static void main(String[] args) {
        

        long start1 = System.currentTimeMillis();
        String res1 = "";
        for (int i = 1; i < 100000; i++) {
            res1 += i;
        }
        System.out.println(System.currentTimeMillis()-start1);
        
        long start2 = System.currentTimeMillis();
        StringBuilder res2 = new StringBuilder();
        for(int i=1;i<100000;i++){
            res2.append(i);
        }
        System.out.println(System.currentTimeMillis()-start2);
        

    }
}

输出结果如下:

19143

47

两种构造字符串的方式,时间开销差的是好几个数量级。究其原因呢,第一种构造字符串的方式使用了重载操作符『+』,会不断的 new一个String Builder 对象,时间开销自然很大。

第二种构造字符串的方法,只生成了一个 StringBuilder对象,相当于原数组修改,时间开销自然少。

因此,当你为一个类编写 toString 方法时,如果字符串操作比较简单,可以考虑用+。

如果再 toString 方法中使用循环,那么最好自己创建一个 StringBuilder 对象,用它来构造最终的结果。

相关文章:

  • 2021-05-25
  • 2022-12-23
  • 2022-01-09
  • 2021-09-21
  • 2021-09-15
  • 2022-12-23
猜你喜欢
  • 2021-11-29
  • 2022-12-23
  • 2021-05-28
  • 2021-06-04
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案