Java中三种方法拼接字符串时间比较

package opt_string;

/**
 * 比较三种方法拼接时间
 * @author Administrator
 *
 */
public class MyString {

    public static void main(String[] args) {
        testBigString();
    }
    /**
     * 比较三种拼接字符串的时间
     */
    static void testBigString() {
        long b1=System.currentTimeMillis();
        String str = "";
        for (int i = 0; i < 10000; i++) {
            str=str+i;
        }
        long e1=System.currentTimeMillis();
        System.out.println(e1-b1);//394ms
        long b2=System.currentTimeMillis();
        String res="";
        for (int i = 0; i < 10000; i++) {
           res=res.concat(String.valueOf(i));
        }
        long e2=System.currentTimeMillis();
        System.out.println(e2-b2);//74ms
        long b3=System.currentTimeMillis();
        StringBuilder sb=new StringBuilder();
        for (int i = 0; i < 10000; i++) {
            sb.append(i);
        }
        long e3=System.currentTimeMillis();
        System.out.println(e3-b3);//0ms
    }

}

从String的+法的反编译发现,他也是使用Stringbuilder来拼接的,但是每次循环都生成一个新的Stringbuilder实例,从而导致性能大大降低,


通过上面三个时间不难看出,对于+,+=尽量少用,String的concat()方法远比+,+=要好,但是Stringbuilder比他更好,



欢迎关注公众号:Java后端技术全栈