Java中测试StringBuilder、StringBuffer、String在字符串拼接上的性能
2024-10-02 07:32:12
应一个大量字符串拼接的任务
测试一下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
最新文章
- 从零开始编写自己的C#框架(28)——建模、架构与框架
- 读书笔记之深入理解Nginx:模块开发与结构解析
- C语言常用知识
- C++ 之 常量成员函数
- 《深度探索C++对象模型》2
- 【转】Java transient关键字
- Create a method synchronized without using synchronized keyword
- RAPIDXML 中文手册,根据官方文档完整翻译!
- [Spark] Pair RDD常见转化操作
- [河南省ACM省赛-第三届] 房间安排 (nyoj 168)
- 实时音视频互动系列(下):基于 WebRTC 技术的实战解析
- Python爬虫基本原理
- 控制成本,控制成本知识点,挣值和实际成本、EAC,ETC.TCPI解析表
- .NET(C#、VB)APP开发——Smobiler平台控件介绍:SignatureButton控件
- 中国居民18位身份证号验证方法,Java算法实现
- [leetcode]300. Longest Increasing Subsequence最长递增子序列
- bash 括号(小括号,双小括号,中括号,双中括号,大括号)
- HTML5拖动
- mysql中,如何查看数据库元数据(metadata)的字符集?
- Solr(一) 安装部署环境
热门文章
- javaScript之表格操作<;一:新增行>;
- J - Joseph and Tests Gym - 102020J (二分+线段树)
- mysql 案例~mysql元数据的sql统计
- python - format函数 /class内置format方法
- u盘的一些理解
- Raw Socket vs Stream Socket vs datagram socket,原始套接字与流式套接字与数据报套接字
- 【转】C/C++内存泄漏及检测
- WallPaper
- expdp和impdp快速导出导入,不用创建虚拟目录
- 解决Javascript中$(window).resize()多次执行