highcharts 大数据 String+,StringBuilder,String.format运行效率比较
实现String字符串相加的方法有很多,常见的有直接相加,StringBuilder.append和String.format,这三者的运行效率是有差异的,String是final类型的,每次相加都会new一个
新的String对象,如果这种操作很多的话,很占用很大的内存。而StringBuilder.append方法是在原对象上进行操作,如果长度不够就自行扩展。
测试代码1:
- <span style="white-space:pre"> </span>String success_code = "0";
- byte splite = 0x01;
- private void method1(){
- String resultMsg = "";
- long time1 = System.nanoTime();
- String.format("ErrorCode=%s%cErrorMsg=心跳包接收成功%c", success_code, splite, splite);
- long time2 = System.nanoTime();
- System.out.println("StringFormat:"+(time2-time1)+"ns");
- long time3 = System.nanoTime();
- resultMsg = "ErrorCode="+success_code+splite+"ErrorMsg=心跳包接收成功"+splite;
- long time4 = System.nanoTime();
- System.out.println("String add:"+(time4-time3)+"ns");
- long time5 = System.nanoTime();
- sb.append("ErrorCode=").append(success_code).append(splite).append("ErrorMsg=心跳包接收成功").append(splite);
- long time6 = System.nanoTime();
- System.out.println("StringBuilder add:"+(time6-time5)+"ns");
- System.out.println("-------------------------------------------------");
- }
- @Test
- public void test1(){
- for(int i=0; i<1000; i++){
- method1();
- }
- }

<span style="white-space:pre"> </span>String success_code = "0";
byte splite = 0x01;
private void method1(){
String resultMsg = "";
long time1 = System.nanoTime();
String.format("ErrorCode=%s%cErrorMsg=心跳包接收成功%c", success_code, splite, splite);
long time2 = System.nanoTime();
System.out.println("StringFormat:"+(time2-time1)+"ns");
long time3 = System.nanoTime();
resultMsg = "ErrorCode="+success_code+splite+"ErrorMsg=心跳包接收成功"+splite;
long time4 = System.nanoTime();
System.out.println("String add:"+(time4-time3)+"ns");
long time5 = System.nanoTime();
sb.append("ErrorCode=").append(success_code).append(splite).append("ErrorMsg=心跳包接收成功").append(splite);
long time6 = System.nanoTime();
System.out.println("StringBuilder add:"+(time6-time5)+"ns");
System.out.println("-------------------------------------------------");
}
@Test
public void test1(){
for(int i=0; i<1000; i++){
method1();
}
}
运行结果:
- StringFormat:58025ns
- String add:3158ns
- StringBuilder add:1579ns
- -------------------------------------------------
- StringFormat:43026ns
- String add:3948ns
- StringBuilder add:1974ns
- -------------------------------------------------
- .....
- StringFormat:46973ns
- String add:1579ns
- StringBuilder add:790ns
- -------------------------------------------------
- StringFormat:52499ns
- String add:1578ns
- StringBuilder add:790ns
- -------------------------------------------------
- StringFormat:43026ns
- String add:1579ns
- StringBuilder add:790ns
- -------------------------------------------------

StringFormat:58025ns
String add:3158ns
StringBuilder add:1579ns
-------------------------------------------------
StringFormat:43026ns
String add:3948ns
StringBuilder add:1974ns
-------------------------------------------------
.....
StringFormat:46973ns
String add:1579ns
StringBuilder add:790ns
-------------------------------------------------
StringFormat:52499ns
String add:1578ns
StringBuilder add:790ns
-------------------------------------------------
StringFormat:43026ns
String add:1579ns
StringBuilder add:790ns
-------------------------------------------------
从上述结果可知,StringBuilder与String直接相加的执行效率都比String.format高, 而StringBuilder的执行效率要比String直接相加要高点。下面针对String,StringBuilder再
做一组测试。
测试代码2:
- <span style="white-space:pre"> </span>public void method2(int num){
- String text = "";
- long beginTime = System.nanoTime();
- for(int i = 0; i < num; i++){
- text += i;
- }
- long endTime = System.nanoTime();
- System.out.println("String直接相加"+num+"次耗费时间:" + (endTime - beginTime)+"ns");
- StringBuilder builder = new StringBuilder("");
- beginTime = System.nanoTime();
- for(int i = 0; i < num; i++){
- builder.append(i);
- }
- endTime = System.nanoTime();
- System.out.println("StringBuilder相加"+num+"次耗费时间:" + (endTime - beginTime)+"ns");
- System.out.println("---------------------------------------------------");
- }
- @Test
- public void test2(){
- method2(10);
- method2(100);
- method2(10000);
- method2(100000);
- }

<span style="white-space:pre"> </span>public void method2(int num){
String text = "";
long beginTime = System.nanoTime();
for(int i = 0; i < num; i++){
text += i;
}
long endTime = System.nanoTime();
System.out.println("String直接相加"+num+"次耗费时间:" + (endTime - beginTime)+"ns");
StringBuilder builder = new StringBuilder("");
beginTime = System.nanoTime();
for(int i = 0; i < num; i++){
builder.append(i);
}
endTime = System.nanoTime();
System.out.println("StringBuilder相加"+num+"次耗费时间:" + (endTime - beginTime)+"ns");
System.out.println("---------------------------------------------------");
}
@Test
public void test2(){
method2(10);
method2(100);
method2(10000);
method2(100000);
}
运行结果:
- String直接相加10次耗费时间:19737ns
- StringBuilder相加10次耗费时间:3553ns
- ---------------------------------------------------
- String直接相加100次耗费时间:56447ns
- StringBuilder相加100次耗费时间:47762ns
- ---------------------------------------------------
- String直接相加10000次耗费时间:266082677ns
- StringBuilder相加10000次耗费时间:999061ns
- ---------------------------------------------------
- String直接相加100000次耗费时间:45212528095ns
- StringBuilder相加100000次耗费时间:3040604ns
- ---------------------------------------------------

String直接相加10次耗费时间:19737ns
StringBuilder相加10次耗费时间:3553ns
---------------------------------------------------
String直接相加100次耗费时间:56447ns
StringBuilder相加100次耗费时间:47762ns
---------------------------------------------------
String直接相加10000次耗费时间:266082677ns
StringBuilder相加10000次耗费时间:999061ns
---------------------------------------------------
String直接相加100000次耗费时间:45212528095ns
StringBuilder相加100000次耗费时间:3040604ns
---------------------------------------------------
从测试结果可分析出,StringBuilder的效率是比String高。
再来看一个测试,代码和上面的一样,只是SringBuilder加上个toString
测试代码:
- String success_code = "0";
- byte splite = 0x01;
- private void method1(){
- String resultMsg = "";
- long time1 = System.nanoTime();
- resultMsg = String.format("ErrorCode=%s%cErrorMsg=心跳包接收成功%c", success_code, splite, splite);
- long time2 = System.nanoTime();
- System.out.println("StringFormat:"+(time2-time1)+"ns");
- long time3 = System.nanoTime();
- resultMsg = "ErrorCode="+success_code+splite+"ErrorMsg=心跳包接收成功"+splite;
- long time4 = System.nanoTime();
- System.out.println("String add:"+(time4-time3)+"ns");
- long time5 = System.nanoTime();
- resultMsg = sb.append("ErrorCode=").append(success_code).append(splite).append("ErrorMsg=心跳包接收成功").append(splite).toString();
- long time6 = System.nanoTime();
- System.out.println("StringBuilder add:"+(time6-time5)+"ns");
- System.out.println("-------------------------------------------------");
- }

String success_code = "0";
byte splite = 0x01;
private void method1(){
String resultMsg = "";
long time1 = System.nanoTime();
resultMsg = String.format("ErrorCode=%s%cErrorMsg=心跳包接收成功%c", success_code, splite, splite);
long time2 = System.nanoTime();
System.out.println("StringFormat:"+(time2-time1)+"ns");
long time3 = System.nanoTime();
resultMsg = "ErrorCode="+success_code+splite+"ErrorMsg=心跳包接收成功"+splite;
long time4 = System.nanoTime();
System.out.println("String add:"+(time4-time3)+"ns");
long time5 = System.nanoTime();
resultMsg = sb.append("ErrorCode=").append(success_code).append(splite).append("ErrorMsg=心跳包接收成功").append(splite).toString();
long time6 = System.nanoTime();
System.out.println("StringBuilder add:"+(time6-time5)+"ns");
System.out.println("-------------------------------------------------");
}
- <span style="white-space:pre"> </span>@Test
- public void test1(){
- for(int i=0; i<10; i++){
- method1();
- }
- }

<span style="white-space:pre"> </span>@Test
public void test1(){
for(int i=0; i<10; i++){
method1();
}
}
运行结果:
- StringFormat:564859ns
- String add:55657ns
- StringBuilder add:3158ns
- -------------------------------------------------
- StringFormat:98683ns
- String add:2368ns
- StringBuilder add:1974ns
- -------------------------------------------------
- StringFormat:69867ns
- String add:2369ns
- StringBuilder add:1974ns
- -------------------------------------------------
- StringFormat:77762ns
- String add:3552ns
- StringBuilder add:2369ns
- -------------------------------------------------
- StringFormat:105788ns
- String add:3948ns
- StringBuilder add:2368ns
- -------------------------------------------------
- StringFormat:78552ns
- String add:2763ns
- StringBuilder add:1974ns
- -------------------------------------------------
- StringFormat:68683ns
- String add:2368ns
- StringBuilder add:1974ns
- -------------------------------------------------
- StringFormat:67894ns
- String add:2369ns
- StringBuilder add:1973ns
- -------------------------------------------------
- StringFormat:67499ns
- String add:2369ns
- StringBuilder add:1974ns
- -------------------------------------------------
- StringFormat:116840ns
- String add:3948ns
- StringBuilder add:3552ns
- -------------------------------------------------

StringFormat:564859ns
String add:55657ns
StringBuilder add:3158ns
-------------------------------------------------
StringFormat:98683ns
String add:2368ns
StringBuilder add:1974ns
-------------------------------------------------
StringFormat:69867ns
String add:2369ns
StringBuilder add:1974ns
-------------------------------------------------
StringFormat:77762ns
String add:3552ns
StringBuilder add:2369ns
-------------------------------------------------
StringFormat:105788ns
String add:3948ns
StringBuilder add:2368ns
-------------------------------------------------
StringFormat:78552ns
String add:2763ns
StringBuilder add:1974ns
-------------------------------------------------
StringFormat:68683ns
String add:2368ns
StringBuilder add:1974ns
-------------------------------------------------
StringFormat:67894ns
String add:2369ns
StringBuilder add:1973ns
-------------------------------------------------
StringFormat:67499ns
String add:2369ns
StringBuilder add:1974ns
-------------------------------------------------
StringFormat:116840ns
String add:3948ns
StringBuilder add:3552ns
-------------------------------------------------
当运行10次时,均显示StringBuilder.append.toString的效率比String的直接相加高。
测试执行10000次,结果如下:
- StringFormat:9079ns
- String add:789ns
- StringBuilder add:153550ns
- -------------------------------------------------
- StringFormat:18552ns
- String add:789ns
- StringBuilder add:141708ns
- -------------------------------------------------
- StringFormat:9078ns
- String add:395ns
- StringBuilder add:122761ns
- -------------------------------------------------

StringFormat:9079ns
String add:789ns
StringBuilder add:153550ns
-------------------------------------------------
StringFormat:18552ns
String add:789ns
StringBuilder add:141708ns
-------------------------------------------------
StringFormat:9078ns
String add:395ns
StringBuilder add:122761ns
-------------------------------------------------
highcharts 大数据 String+,StringBuilder,String.format运行效率比较的更多相关文章
- String+ String.Concat String.Format StringBuilder 之间的性能测试
找到一篇国外的代码,专门来测试这个, String+ String.Concat String.Format StringBuilder 前三个在100个左右字符串差不多, String.Concat ...
- [C#] string 与 String,大 S 与小 S 之间没有什么不可言说的秘密
string 与 String,大 S 与小 S 之间没有什么不可言说的秘密 目录 小写 string 与大写 String 声明与初始化 string string 的不可变性 正则 string ...
- difference among String,StringBuilder,StringBuffer
difference among String,StringBuilder,StringBuffer String常用构造函数 String(byte[] bytes) String(byte[] b ...
- String StringBuilder StringBuffer 对比 总结得非常好
转自:http://www.iteye.com/topic/522167 作者:每次上网冲杯Java时,都能看到关于String无休无止的争论.还是觉得有必要让这个讨厌又很可爱的String美眉,赤裸 ...
- 谈String,StringBuilder,StringBuffer随笔
一.谈谈三者在实现上的区别. (1)先看String 方法,实现了Serializable, Comparable, CharSequence三个接口 package java.lang; imp ...
- (转)String StringBuilder StringBuffer 对比 总结得非常好
来源:http://blog.csdn.net/clam_clam/article/details/6831345 转自:http://www.iteye.com/topic/522167 作者:每次 ...
- Java中 StringBuffer StringBuilder String 区别
String 字符串常量 不可变 使用字符串拼接时是不同的2个空间 StringBuffer 字符串变量 可变 线程安全 字符串拼接直接在字符串后追加 StringBui ...
- Android jni/ndk编程二:jni数据类型转换(primitive,String,array)
一.数据类型映射概述 从我们开始jni编程起,就不可能避开函数的参数与返回值的问题.java语言的数据类型和c/c++有很多不同的地方,所以我们必须考虑当在java层调用c/c++函数时,怎么正确的把 ...
- StringBuffer StringBuilder String 区别
String 字符串常量 不可变 使用字符串拼接时是不同的2个空间 StringBuffer 字符串变量 可变 线程安全 字符串拼接直接在字符串后追加 StringBui ...
随机推荐
- MySQL中count函数使用方法详解
count函数是用来统计表中或数组中记录的一个函数,下面我来介绍在MySQL中count函数用法与性能比较吧. count(*) 它返回检索行的数目, 不论其是否包含 NULL值. SELECT ...
- css 网格布局简单应用
将属性 display 值设为 grid 或 inline-grid 就创建了一个网格容器,所有容器直接子结点自动成为网格项目. grid :网格项目按行排列,网格项目占用整个容器的宽度. inlin ...
- Java 获取当前日期的几种方法
import java.text.DateFormat; import java.text.SimpleDateFormat; import java.util.Calendar; import ja ...
- Java反射通过getter和setter方法实现类的拷贝
private User copyFieldValues(User userData, User user) { Field[] fields = user.getClass().getDeclare ...
- php获取文章的第一张图片
今天做东西的时候遇到一个问题就是如何把文章提取出来作为文章列表呢? 因为用了Ueditor,所以提交的数据包含了html标签. 搜索了一会找到了一个方案,用php自带的函数去掉了html标签. $ar ...
- __x__(38)0909第五天__雪碧图的制作
1. 用ps打开目标图片若干. 2. 调整合适的画布大小. 3. 将图片拖曳到一张里. 4. 存储为Web所用格式,选择 png24 .
- vue_条件渲染_v-if_v-else_v-show
data: { ok: true flag: false } 1. 成对出现的 v-if 和 v-else 原理是: 标签的删除与重新创建 ,有些情况必须用 v-if <p v-if=" ...
- Java课程寒假之回答问题:如何将你的兴趣化为可以立足于社会的资本
在学校的时候干过几次兼职,算是无聊时候的外快吧,有一次是去辅导机构,在考试期间监考学生,前后大概四个小时,最后拿了四十五并且管了一顿饭,不得不说,小学生是真的皮,考试的时候有的爱讲话,有的是写完之后开 ...
- Linux服务器tomcat无法通过ip加端口访问
Linux服务器tomcat无法通过ip加端口访问 防火墙开放端口 # Firewall configuration written by system-config-firewall# Manual ...
- Overview of .rdp file settings
On this page you will find an overview of most of the available .rdp file settings which can be used ...