java stringbuilder stringformat 速度比较

1.一个一个地连接
//验证代码
for (int i = 0; i < 100; i++) {
    long start = System.nanoTime();
    String str = "";
    str += protocol;
    str += "://";
    str += domain;
    str += ":";
    str += port;
    str += "/";
    str += args1;
    str += "/";
    str += args2;
    str += "?";
    str += queryKey;
    str += "=";
    str += queryValue;
    long end = System.nanoTime();
    System.out.println(end - start);
}


//实际的速度
最大値:565394 ns
最小値:7225 ns
平均値:16901.71 ns
中央値:9757 ns




2.一起连接
// 验证代码
for (int i = 0; i < 10; i++) {
    long start2 = System.nanoTime();
    String s = protocol + "://" + domain + 
        ":" + port + "/" + args1 + "/" + args2 + "?" + queryKey + "=" + queryValue;
    long end2 = System.nanoTime();
    System.out.println((end2 - start2) + "ns");
}

// 实际的速度
最大値:63929 ns
最小値:1767 ns
平均値:4353.32 ns
中央値:2265 ns


3. string.format
// 验证代码
for (int i = 0; i < 100; i++) {
    long start = System.nanoTime();
    String.format("%s://%s:%s/%s/%s?%s=%s", protocol, 
        domain, port, args1, args2, queryKey, queryValue);
    long end = System.nanoTime();
    System.out.println(end - start);
}

// 实际的速度
最大値:31263865 ns
最小値:56854 ns
平均値:466271.38 ns
中央値:119898.5 ns


4. StringBuilder
// 验证代码
for (int i = 0; i < 100; i++) {
    long start = System.nanoTime();
    String str = new StringBuilder(protocol).append("://")
        .append(domain).append(":").append(port).append("/")
        .append(args1).append("/").append(args2).append("?").append(queryKey)
        .append("=").append(queryValue).toString();
    long end = System.nanoTime();
    System.out.println(end - start);
}

// 实际的速度
最大値:56699 ns
最小値:2000 ns
平均値:3896.39 ns

中央値:2442.5 ns


单位:ns   1.一个一个地连接     2.一起连接       3. String.format       4. StringBuilder
最大値     565394                         63929                31263865                 56699
最小値     7225                             1767                  56854                       2000
平均値     16901.71                      4353.32             466271.38                3896.39
中央値     9757                             2265                  119898.5                  2442.5

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值