zoukankan      html  css  js  c++  java
  • 字符串拼接性能比较出乎意料的结果

     一直认为String拼接大字符串时用StringBuffer能比直接用+号性能更高,今天偶然发现不竟然,是有前提的。如果String对象没用重新赋值,而是一次性把字符串拼接好赋值给String变量时性能是最高的(第二个例子String2)。如果String使用的是+=重新赋值,这时性能确实要比StringBuffer慢2-3倍左右(第一个例子String1)。

    public static void main(String[] args) {
            long startTime = System.currentTimeMillis();
            for (int i = 0; i < 100000; i++) {
                String result = "This is ";
                result += "testing the";
                result += "difference between";
                result += "String and StringBuffer";
            }
            long endTime = System.currentTimeMillis();
            System.out.println(String.format("String+ 1 cost: %s millis", (endTime - startTime)));
    
            startTime = System.currentTimeMillis();
            for (int i = 0; i < 100000; i++) {
                String result = "This is" + "testing the" + "difference" + "between" + "String" + "and" + "StringBuffer";
            }
            endTime = System.currentTimeMillis();
            System.out.println(String.format("String+ 2  cost: %s millis", (endTime - startTime)));
    
            startTime = System.currentTimeMillis();
            for (int i = 0; i < 100000; i++) {
                StringBuffer sbResult = new StringBuffer();
                sbResult.append("This is ");
                sbResult.append("testing the");
                sbResult.append("difference between");
                sbResult.append("String and StringBuffer");
                sbResult.toString();
            }
            endTime = System.currentTimeMillis();
            System.out.println(String.format("StringBuffer cost: %s millis", (endTime - startTime)));
        }

    运行结果:

  • 相关阅读:
    多线程 信号量
    sql在不同数据库查询前几条数据
    Office Outlook同步 很奇怪的BUG
    搜索小技巧整理
    想做一个权限管理插件
    ibatis和Castle学习历程
    查找存储过程中的错误位置
    VS2005项目模版丢失解决方案及VS2005项目模版查找原理
    C# 邮件发送接收
    数据库优化整合
  • 原文地址:https://www.cnblogs.com/mousewheel/p/7401320.html
Copyright © 2011-2022 走看看