应一个大量字符串拼接的任务

测试一下StringBuilder、StringBuffer、String在操作字符串拼接时候的性能

性能上理论是StringBuilder  >  StringBuffer  >  String

测试方法:

创建一个StirngTest类含有静态常量字符串是26个字母,以及一个循环轮数

在测试时采用循环来操作字符串的拼接,计算操作时间并输出:

package com.test.xlc;

import java.util.Random;

public class StringTest {

    static final String strFinal = "abcdefghijklmnopqrstovwxyz";
static final int forInt = 100; static void StringBuilderTest() { Random rand = new Random(47);
StringBuilder strB = new StringBuilder();
long start = System.currentTimeMillis();
for(int i = 0; i < forInt; ++i) {
int randInt = rand.nextInt(23);
strB.append(strFinal.substring(randInt, randInt + 4));
}
long end = System.currentTimeMillis();
// System.out.println(strB.toString());
System.out.println("StringBuilderTest:" + (end - start));
} static void StringBufferTest() {
Random rand = new Random(47);
StringBuffer strB = new StringBuffer();
long start = System.currentTimeMillis();
for(int i = 0; i < forInt; ++i) {
int randInt = rand.nextInt(23);
strB.append(strFinal.substring(randInt, randInt + 4));
}
long end = System.currentTimeMillis();
// System.out.println(strB.toString());
System.out.println("StringBufferTest:" + (end - start));
} static void StringOnly() {
Random rand = new Random(47);
String str = "";
long start = System.currentTimeMillis();
for(int i = 0; i < forInt; ++i) {
int randInt = rand.nextInt(23);
str += strFinal.substring(randInt, randInt + 4);
}
long end = System.currentTimeMillis();
// System.out.println(str);
System.out.println("String:" + (end - start));
} public static void main(String...args) {
StringBuilderTest();
StringBufferTest();
StringOnly(); }
}

测试循环次数:

100

StringBuilderTest:0
StringBufferTest:0
String:0

1000

StringBuilderTest:1
StringBufferTest:0
String:7

10000

StringBuilderTest:2
StringBufferTest:2
String:217

100000

StringBuilderTest:12
StringBufferTest:10
String:17136

1000000

StringBuilderTest:55
StringBufferTest:53
我提前终止了

之后我又测试了拼接长串,本实验结果显示在拼接字符串的效率上:

StringBuffer  >    StringBuilder  >  String

最新文章

  1. 从零开始编写自己的C#框架(28)——建模、架构与框架
  2. 读书笔记之深入理解Nginx:模块开发与结构解析
  3. C语言常用知识
  4. C++ 之 常量成员函数
  5. 《深度探索C++对象模型》2
  6. 【转】Java transient关键字
  7. Create a method synchronized without using synchronized keyword
  8. RAPIDXML 中文手册,根据官方文档完整翻译!
  9. [Spark] Pair RDD常见转化操作
  10. [河南省ACM省赛-第三届] 房间安排 (nyoj 168)
  11. 实时音视频互动系列(下):基于 WebRTC 技术的实战解析
  12. Python爬虫基本原理
  13. 控制成本,控制成本知识点,挣值和实际成本、EAC,ETC.TCPI解析表
  14. .NET(C#、VB)APP开发——Smobiler平台控件介绍:SignatureButton控件
  15. 中国居民18位身份证号验证方法,Java算法实现
  16. [leetcode]300. Longest Increasing Subsequence最长递增子序列
  17. bash 括号(小括号,双小括号,中括号,双中括号,大括号)
  18. HTML5拖动
  19. mysql中,如何查看数据库元数据(metadata)的字符集?
  20. Solr(一) 安装部署环境

热门文章

  1. javaScript之表格操作&lt;一:新增行&gt;
  2. J - Joseph and Tests Gym - 102020J (二分+线段树)
  3. mysql 案例~mysql元数据的sql统计
  4. python - format函数 /class内置format方法
  5. u盘的一些理解
  6. Raw Socket vs Stream Socket vs datagram socket,原始套接字与流式套接字与数据报套接字
  7. 【转】C/C++内存泄漏及检测
  8. WallPaper
  9. expdp和impdp快速导出导入,不用创建虚拟目录
  10. 解决Javascript中$(window).resize()多次执行