string stringbuffer stringbuilder的执行效率
来源:互联网 发布:value at risk python 编辑:程序博客网 时间:2024/05/16 16:09
相信大家对这三个小家伙都挺熟悉的,但是真要要说他们在使用时的效率问题可能一大部分初学者不是很清楚;本人也是近来在项目中用到 本着刨根问底的态度写了一段代码验证查看执行效率问题,结果表明千万级别的字符串拼接 使用string需要几十秒,使用stringbuffer需要1秒左右,但是StringBuilder只需要几百毫秒 这差距简直逆天了
此处不考虑线程安全,验证的只是字符串拼接时的执行效率,实际使用过程中看情况而定,不多废话上代码;
package com.demo;
import java.sql.Timestamp;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Random;
import java.util.Set;
import java.util.TreeMap;
public class test {
public static void main(String[] args) {
//string执行效率
long startTime = System.currentTimeMillis(); //获取开始时间
String a="";
for (int i = 0; i < 100000; i++) {
a = a+"+"+i;
}; //测试的代码段
long endTime = System.currentTimeMillis(); //获取结束时间
// System.out.println("a=" + a); //输出程序运行时间
System.out.println("string拼接字符串运行时间:" + (endTime - startTime) + "ms"); //输出程序运行时间
//StringBuffer执行效率
long startTime1 = System.currentTimeMillis(); //获取开始时间
StringBuffer b = new StringBuffer();
for (int j = 0; j < 10000000; j++) {
b = b.append("+").append(j);
}; //测试的代码段
long endTime1 = System.currentTimeMillis(); //获取结束时间
// System.out.println("b=" + b); //输出程序运行时间
System.out.println("StringBuffer拼接字符串运行时间:" + (endTime1 - startTime1) + "ms"); //输出程序运行时间
//StringBuilder执行效率
long startTime2 = System.currentTimeMillis(); //获取开始时间
StringBuilder c = new StringBuilder();
for (int h = 0; h < 10000000; h++) {
c = c.append("+").append(h);
}; //测试的代码段
long endTime2 = System.currentTimeMillis(); //获取结束时间
// System.out.println("c=" + c); //输出程序运行时间
System.out.println("StringBuilder拼接字符串运行时间:" + (endTime2 - startTime2) + "ms"); //输出程序运行时间
}
}
- string stringbuffer stringbuilder的执行效率
- String, StringBuffer, StringBuilder拼接字符串的执行效率比较
- String,StringBuffer,StringBuilder的效率问题
- String,StringBuffer,StringBuilder,StringWriter的效率差
- String,StringBuffer,StringBuilder的效率区别
- 测试String StringBuilder StringBuffer 的执行速度
- String,StringBuilder,StringBuffer效率比较
- String,StringBuffer,StringBuilder拼接操作的效率对比
- 拼接字符串的效率问题(String,StringBuffer,StringBuilder对比)
- java中String、StringBuilder和StringBuffer效率的比较
- String、StringBuffer、StringBuilder的区别与效率比较
- String,StringBuffer,StringBuilder区别与效率
- Java字符串连接效率 String、StringBuilder、StringBuffer
- String、StringBuffer、StringBuilder区别及效率
- StringBuilder 与string 执行替换时的效率测试
- String,StringBuffer,StringBuilder的区别
- String StringBuffer StringBuilder的区别
- String, StringBuffer, StringBuilder的区别?
- 使用WebSocket实现即使通讯(实现一个群聊的聊天室)
- 千兆网线做法和网线接法注意事项
- 一步一步学习 ReactNative + Redux(6)
- android studio 中实现二维码扫描
- 移动端禁止长按图片弹出系统功能列表和禁止文本选择
- string stringbuffer stringbuilder的执行效率
- LeetCode#31. Next Permutation
- 关于expected identifier or ‘(’ before***的错误
- 高德地图Android开发-环境配置
- 装修注意事项总结
- 读取HDFS上的文件时报错
- python2.7 x64版本下pymssql的安装及数据库连接代码
- Result Maps collection already contains value for cn.itcast.ssm.mapper.Items的原因及解决办法
- 循环队列的实现