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 语言中重要的数据类型,是内存中占用空间最大的一个对象,高效地使用字符串, ...
随机推荐
- Leetcode 435.无重叠区间
无重叠区间 给定一个区间的集合,找到需要移除区间的最小数量,使剩余区间互不重叠. 注意: 可以认为区间的终点总是大于它的起点. 区间 [1,2] 和 [2,3] 的边界相互"接触" ...
- UVA11367 Full Tank? 【分层图最短路】
题目 After going through the receipts from your car trip through Europe this summer, you realised that ...
- docker (centOS 7) 使用笔记1
1. docker配置 初次在安装完docker后,初始化配置 copy默认的docker.service后,重启服务,会在/etc/systemd/system/multi-user.target. ...
- [SDOI2010] 地精部落 (组合数学,动态规划)
题目链接 Solution 很巧妙的 DP. 可以看这里的题解. 比我自己讲要好的多. Code #include <bits/stdc++.h> using namespace std; ...
- hdu 3264 圆的交+二分
Open-air shopping malls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/ ...
- Mysql之禁止使用索引
禁止使用索引:ignore index---------------------强制使用索引: force index mysql> explain select * from userinfo ...
- 标准C程序设计七---71
Linux应用 编程深入 语言编程 标准C程序设计七---经典C11程序设计 以下内容为阅读: <标准C程序设计>(第7版) 作者 ...
- Linux 之 Memcached
Memcached的安装使用 参考教程:[千峰教育] 环境:CentOS 6.8 一.简介: memcached作为高速运行的分布式缓存服务器,具有以下的特点. · 协议简单 · 基于libevent ...
- ThinkPHP 5.1 基础知识
==========================================//模板中的默认标题{$title|default='默认标题'}========================= ...
- 转载:Flappy Bird源代码 win32 console版
#include"StdAfx.h" #include<stdio.h> #include<stdlib.h> #include<conio.h> ...