String,StringBuilder性能对照
import java.util.Date;
import java.util.UUID;
/**
* 測试String,StringBuilder性能,推断什么时候改用String,什么时候该用StringBuilder
* 測试结果
* String 拼接測试,測试长度10000,測试字符串数组长度30,完毕时间721
StringBuilder 拼接測试,測试长度10000,測试字符串数组长度30,完毕时间315
String 拼接測试,測试长度10000,測试字符串数组长度10,完毕时间301
StringBuilder 拼接測试,測试长度10000,測试字符串数组长度10,完毕时间124
String 拼接測试,測试长度10000,測试字符串数组长度5,完毕时间237
StringBuilder 拼接測试,測试长度10000,測试字符串数组长度5,完毕时间68
String 拼接測试,測试长度10000,測试字符串数组长度50,完毕时间1169
StringBuilder 拼接測试,測试长度10000,測试字符串数组长度50,完毕时间504
String 拼接測试,測试长度10000,測试字符串数组长度2,完毕时间188
StringBuilder 拼接測试,測试长度10000,測试字符串数组长度2,完毕时间31
String 拼接測试,測试长度20000,測试字符串数组长度2,完毕时间253
StringBuilder 拼接測试,測试长度20000,測试字符串数组长度2,完毕时间59
*
* 这几组至少是2倍以上的时间差距,
* 当然小范围的拼接差点儿时间都是能够忽略不计的,可是你假设作为工具类或者大范围的拼接不妨用StringBuilder,哪怕仅仅是拼接两个字符串
* @author JueYue
*
*/
public class StringTest {
public static void main(String[] args) {
int testLength = 10000;
String[] arr = new String[2];
Date start = new Date();
String str = "";
for (int i = 0; i < testLength; i++) {
str = "";
for (int j = 0; j < arr.length; j++) {
str += UUID.randomUUID().toString();
}
}
System.out.println("String 拼接測试,測试长度" + testLength + ",測试字符串数组长度"
+ arr.length + ",完毕时间"
+ (new Date().getTime() - start.getTime()));
start = new Date();
StringBuilder sb;
for (int i = 0; i < testLength; i++) {
sb = new StringBuilder();
for (int j = 0; j < arr.length; j++) {
sb.append(UUID.randomUUID().toString());
}
}
System.out.println("StringBuilder 拼接測试,測试长度" + testLength + ",測试字符串数组长度"
+ arr.length + ",完毕时间"
+ (new Date().getTime() - start.getTime()));
}
}
String,StringBuilder性能对照的更多相关文章
- 不同Framework下StringBuilder和String的性能对比,及不同Framework性能比(附Demo)
本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 环境搭建 测试用例 MSDN说明 ...
- 从.Net版本演变看String和StringBuilder性能之争
在C#中string关键字的映射实际上指向.NET基类System.String.System.String是一个功能非常强大且用途非常广泛的基类,所以我们在用C#string的时候实际就是在用.NE ...
- java中String StringBuilder StringBuffer比较和效率(性能)测试
string stringbuilder stringbuffer三者的区别 从JDK源码看,String.StringBuilder.StringBuffer都是存放在char[] 数组字符串. 简 ...
- java String、String.concat和StringBuilder性能对比
看到网上有人已经做过对比,并且贴出了代码,然后我运行了之后发现跟我分析的结论差距很大.发现他的代码有个问题,UUID.randomUUID() 首次调用耗时会很高,这个耗时被计算给了String,这对 ...
- String, StringBuilder, StringBuffer问题
1. 区别 String为字符串常量,而StringBuilder和StringBuffer都是字符串变量,其中StringBuilder线程非安全,StringBuffer线程安全. 每次对 Str ...
- Java基础学习总结(65)——Java中的String,StringBuilder和StringBuffer比较
字符串,就是一系列字符的集合. Java里面提供了String,StringBuffer和StringBuilder三个类来封装字符串,其中StringBuilder类是到jdk 1.5才新增的.字符 ...
- String字符串性能优化的几种方案
String字符串是系统里最常用的类型之一,在系统中占据了很大的内存,因此,高效地使用字符串,对系统的性能有较好的提升. 针对字符串的优化,我在工作与学习过程总结了以下三种方案作分享: 一.优化构建的 ...
- 【Unity|C#】基础篇(17)——字符串处理(String/StringBuilder)
[学习资料] <C#图解教程>(第25章):https://www.cnblogs.com/moonache/p/7687551.html 电子书下载:https://pan.baidu. ...
- String字符串性能优化的探究
一.背景 String 对象是我们使用最频繁的一个对象类型,但它的性能问题却是最容易被忽略的.String 对象作为 Java 语言中重要的数据类型,是内存中占用空间最大的一个对象,高效地使用字符串, ...
随机推荐
- Python包和日志模块
1.什么是包 包是模块的一种形式,包的本质就是一个含有__init__.py文件的文件夹 2.为什么要有包 提高开发人员维护性 3.如何用包 导入包就是在导包下的__init__.py ...
- linux 系统时间调整
linux的硬件时间是从COMS中读取的. 系统时间是由操作系统维护的. 先查看时区是否正确 (东八区 +8) #date -R 选择时区: #tzselect 修改了系统时间,还应该跟硬件时间进行同 ...
- Unity3D - UGUI的初级应用
添加字体: 把下载好的字体拖拽到Project面板中 - 点击Text组件中Text属性后面的圆点 - 选择刚刚拖拽的字体即可. 创建ToggleGroup(开关组): 1.在Canvas下创建两个T ...
- curl保存图片
$url = 'http://p1.qhimg.com/t013dfc89f8a039122c.jpg?size=690x460'; function http_get_data($url) { $c ...
- 记账APP市场分析
文/欧小慧(简书作者)原文链接:http://www.jianshu.com/p/281fcdce3baa著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 一.市场环境 1.理财记账类用 ...
- 周赛Problem 1021: 分蛋糕(埃拉托斯特尼筛法)
Problem 1021: 分蛋糕 Time Limits: 1000 MS Memory Limits: 65536 KB 64-bit interger IO format: %lld ...
- HDU——1272小希的迷宫(并查集+拓扑排序)
小希的迷宫 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Subm ...
- HDU——4162Shape Number(字符串的最小表示)
Shape Number Time Limit: 24000/12000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- [cogs729]圆桌问题(最大流)
传送门 模型 二分图多重匹配问题,可以用最大流解决. 实现 建立二分图,每个单位为X集合中的顶点,每个餐桌为Y集合中的顶点,增设附加源S和汇T. 1.从S向每个Xi顶点连接一条容量为该单位人数的有向边 ...
- P2258 子矩阵 (搜索,动态规划)
题目链接 Solution 搜索+DP. 刚好把搜索卡死的数据范围... 然后应该可以很容易想到枚举行的情况,然后分列去DP. 行的情况直接全排列即可,复杂度最高 \(O(C_{16}^{8})\). ...