码迷,mamicode.com
首页 > 其他好文 > 详细

StringBuffer的拼接效率小细节

时间:2017-07-27 10:43:46      阅读:148      评论:0      收藏:0      [点我收藏+]

标签:span   end   创建   代码   rgs   rom   效率   实践   style   

最近看项目代码发现经常StringBuffer拼接SQL里面有这样的代码sql.append("select * from XXX where xxx="+xxx+" and yyy="+yyy);

于是我很好奇这样写是按顺序连续append还是先创建一个StringBuffer对象append全部String,然后再传送到sql对象中去

实践检验代码如下

    public static void main(String[] args){
        t(9);
        
    }
    private static void t( int q){
        StringBuffer sb=new StringBuffer();
        long start=System.currentTimeMillis();
        for(int i=0;i<200000;i++){
            sb.append("11111111111111"+q+"11111111111111"+q+"111111111111111"+q);
        }
        long end=System.currentTimeMillis();
        long start2=System.currentTimeMillis();
        for(int i=0;i<200000;i++){
            sb.append("11111111111111");
            sb.append(q);
            sb.append("11111111111111");
            sb.append(q);
            sb.append("11111111111111");
            sb.append(q);
            
        }
        long end2=System.currentTimeMillis();
        
        long start3=System.currentTimeMillis();
        for(int i=0;i<200000;i++){
            sb.append("11111111111111"+q);
            sb.append("11111111111111"+q);
            sb.append("11111111111111"+q);
            
        }
        long end3=System.currentTimeMillis();
        System.out.println(start-end);
        System.out.println(start2-end2);
        System.out.println(start3-end3);
    }
    //console输出如下:
    //-140
    //-31
    //-125

备注:

因为预编译会把所有已知的String拼接成一起,所以拼接中必须要是未知数。

String的每一次拼接参数会创建一个StringBuffer对象,单条String拼接次数越多耗费StringBuffer创建资源也就越多。

结论:

StringBuffer的拼接过程中应该尽量保证已知String与未知变量分离sppend,可节约资源。

 

StringBuffer的拼接效率小细节

标签:span   end   创建   代码   rgs   rom   效率   实践   style   

原文地址:http://www.cnblogs.com/blackdeng/p/7243318.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!