- 浏览: 367234 次
- 性别:
- 来自: 重庆
文章分类
- 全部博客 (98)
- J2EE (16)
- 杂谈 (10)
- ibatis (1)
- 正则表达式 (2)
- extjs (6)
- plsql developer (1)
- javascript (18)
- oracle (2)
- eclipse (4)
- java (4)
- IT管理 (2)
- 加密解密 (4)
- linux (2)
- web前端 (5)
- chrome (1)
- J2EE hibernate (0)
- ruby (10)
- rails (8)
- mac (1)
- mysql (3)
- luajava (1)
- css (3)
- 分页按钮控件 (1)
- 编程思想 (2)
- github (1)
- 设计模式 (1)
- hibernate (1)
- highcharts (1)
- map (1)
- intelliJ idea (1)
- sql (1)
- maven (1)
- layui (1)
最新评论
-
an8695001:
大神,这个支持ajax获取数据来分页吗?
仿淘宝分页按钮效果简单美观易使用的JS分页控件 -
aspwzmuma:
太好了~感谢作者~~!!
仿淘宝分页按钮效果简单美观易使用的JS分页控件 -
GlacialDrift:
click 模式下面 不能重新初始化吗?
仿淘宝分页按钮效果简单美观易使用的JS分页控件 -
jia_xin:
请问同一个页面可以支持多个分页么?
仿淘宝分页按钮效果简单美观易使用的JS分页控件 -
zhouxi:
有没有完整的代码做参考啊 那个网站必须注册,而且注册还需要邀请 ...
echarts实现环形进度图
在JAVA中拼接两个字符串的最简便的方式就是使用操作符”+”了。如果你用”+”来连接固定长度的字符串,可能性能上会稍受影响,但是如果你是在循环中来”+”多个串的话,性能将指数倍的下降。假设有一个字符串,我们将对这个字符串做大量循环拼接操作,使用”+”的话将得到最低的性能。但是究竟这个性能有多差?如果我们同时也把StringBuffer,StringBuilder或String.concat()放入性能测试中,结果又会如何呢?本文将会就这些问题给出一个答案!
我们将使用Per4j来计算性能,因为这个工具可以给我们一个完整的性能指标集合,比如最小,最大耗时,统计时间段的标准偏差等。在测试代码中,为了得到一个准确的标准偏差值,我们将执行20个拼接”*”50,000次的测试。下面是我们将使用到的拼接字符串的方法:
Concatenation Operator (+)
String concat method – concat(String str)
StringBuffer append method – append(String str)
StringBuilder append method – append(String str)
最后,我们将看看字节码,来研究这些方法到底是如何执行的。现在,让我们先开始来创建我扪的类。注意为了计算每个循环的性能,代码中的每段测试代码都需要用Per4J库进行封装。首先我们先定义迭代次数
1 private static final int OUTER_ITERATION=20;
2 private static final int INNER_ITERATION=50000;
接下来,我们将使用上述4个方法来实现我们的测试代码。
01 String addTestStr = "";
02 String concatTestStr = "";
03 StringBuffer concatTestSb = null;
04 StringBuilder concatTestSbu = null;
05 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
06 StopWatch stopWatch = new LoggingStopWatch("StringAddConcat");
07 addTestStr = "";
08 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
09 addTestStr += "*";
10 stopWatch.stop();
11 }
12 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
13 StopWatch stopWatch = new LoggingStopWatch("StringConcat");
14 concatTestStr = "";
15 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
16 concatTestStr.concat("*");
17 stopWatch.stop();
18 }
19 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
20 StopWatch stopWatch = new LoggingStopWatch("StringBufferConcat");
21 concatTestSb = new StringBuffer();
22 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
23 concatTestSb.append("*");
24 stopWatch.stop();
25 }
26 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
27 StopWatch stopWatch = new LoggingStopWatch("StringBuilderConcat");
28 concatTestSbu = new StringBuilder();
29 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
30 concatTestSbu.append("*");
31 stopWatch.stop();
32 }
接下来通过运行程序来生成性能指标。我的运行环境是64位的Windown7操作系统,32位的JVM(7-ea) 带4GB内存,双核Quad 2.00GHz的CPU的机器.
经过20次迭代后,我们得到如下的数据:
结果非常完美如我们想象的那样。唯一比较有趣的事情是为什么String.concat也很不错,我们都知道,String是一个常类(初始化后就不会改变的类),那么为什么concat的性能会更好一些呢。(译者注:其实原文作者的测试代码有问题,对于concat()方法的测试代码应该写成concatTestStr=concatTestStr.concat(“*”)才对。)为了回答这个问题,我们应该看看concat反编译出来的字节码。在本文的下载包里面包含了所有的字节码,但是现在我们先看一下concat的这个代码片段:
01 46: new #6; //class java/lang/StringBuilder
02 49: dup
03 50: invokespecial #7; //Method java/lang/StringBuilder."<init>":()V
04 53: aload_1
05 54: invokevirtual #8; //Method java/lang/StringBuilder.append:
06 (Ljava/lang/String;)Ljava/lang/StringBuilder;
07 57: ldc #9; //String *
08 59: invokevirtual #8; //Method java/lang/StringBuilder.append:
09 (Ljava/lang/String;)Ljava/lang/StringBuilder;
10 62: invokevirtual #10; //Method java/lang/StringBuilder.toString:()
11 Ljava/lang/String;
12 65: astore_1
13 66: iinc 7, 1
14 69: goto 38
这段代码是String.concat()的字节码,从这段代码中,我们可以清楚的看到,concat()方法使用了StringBuilder,concat()的性能应该和StringBuilder的一样好,但是由于额外的创建StringBuilder和做.append(str).append(str).toString()的操作,使得concate的性能会受到一些影响,所以StringBuilder和String Cancate的时间是1.8和3.3。
因此,即时在做最简单的拼接时,如果我们不想创建StringBuffer或StringBuilder实例使,我们也因该使用concat。但是对于大量的字符串拼接操作,我们就不应该使用concat(译者注:因为测试代码功能上并不完全等价,更换后的测试代码concat的平均处理时间是1650.9毫秒。这个结果在原文的评论里面。),因为concat会降低你程序的性能,消耗你的cpu。因此,在不考虑线程安全和同步的情况下,为了获得最高的性能,我们应尽量使用StringBuilder
我们将使用Per4j来计算性能,因为这个工具可以给我们一个完整的性能指标集合,比如最小,最大耗时,统计时间段的标准偏差等。在测试代码中,为了得到一个准确的标准偏差值,我们将执行20个拼接”*”50,000次的测试。下面是我们将使用到的拼接字符串的方法:
Concatenation Operator (+)
String concat method – concat(String str)
StringBuffer append method – append(String str)
StringBuilder append method – append(String str)
最后,我们将看看字节码,来研究这些方法到底是如何执行的。现在,让我们先开始来创建我扪的类。注意为了计算每个循环的性能,代码中的每段测试代码都需要用Per4J库进行封装。首先我们先定义迭代次数
1 private static final int OUTER_ITERATION=20;
2 private static final int INNER_ITERATION=50000;
接下来,我们将使用上述4个方法来实现我们的测试代码。
01 String addTestStr = "";
02 String concatTestStr = "";
03 StringBuffer concatTestSb = null;
04 StringBuilder concatTestSbu = null;
05 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
06 StopWatch stopWatch = new LoggingStopWatch("StringAddConcat");
07 addTestStr = "";
08 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
09 addTestStr += "*";
10 stopWatch.stop();
11 }
12 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
13 StopWatch stopWatch = new LoggingStopWatch("StringConcat");
14 concatTestStr = "";
15 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
16 concatTestStr.concat("*");
17 stopWatch.stop();
18 }
19 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
20 StopWatch stopWatch = new LoggingStopWatch("StringBufferConcat");
21 concatTestSb = new StringBuffer();
22 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
23 concatTestSb.append("*");
24 stopWatch.stop();
25 }
26 for (int outerIndex=0;outerIndex<=OUTER_ITERATION;outerIndex++) {
27 StopWatch stopWatch = new LoggingStopWatch("StringBuilderConcat");
28 concatTestSbu = new StringBuilder();
29 for (int innerIndex=0;innerIndex<=INNER_ITERATION;innerIndex++)
30 concatTestSbu.append("*");
31 stopWatch.stop();
32 }
接下来通过运行程序来生成性能指标。我的运行环境是64位的Windown7操作系统,32位的JVM(7-ea) 带4GB内存,双核Quad 2.00GHz的CPU的机器.
经过20次迭代后,我们得到如下的数据:
结果非常完美如我们想象的那样。唯一比较有趣的事情是为什么String.concat也很不错,我们都知道,String是一个常类(初始化后就不会改变的类),那么为什么concat的性能会更好一些呢。(译者注:其实原文作者的测试代码有问题,对于concat()方法的测试代码应该写成concatTestStr=concatTestStr.concat(“*”)才对。)为了回答这个问题,我们应该看看concat反编译出来的字节码。在本文的下载包里面包含了所有的字节码,但是现在我们先看一下concat的这个代码片段:
01 46: new #6; //class java/lang/StringBuilder
02 49: dup
03 50: invokespecial #7; //Method java/lang/StringBuilder."<init>":()V
04 53: aload_1
05 54: invokevirtual #8; //Method java/lang/StringBuilder.append:
06 (Ljava/lang/String;)Ljava/lang/StringBuilder;
07 57: ldc #9; //String *
08 59: invokevirtual #8; //Method java/lang/StringBuilder.append:
09 (Ljava/lang/String;)Ljava/lang/StringBuilder;
10 62: invokevirtual #10; //Method java/lang/StringBuilder.toString:()
11 Ljava/lang/String;
12 65: astore_1
13 66: iinc 7, 1
14 69: goto 38
这段代码是String.concat()的字节码,从这段代码中,我们可以清楚的看到,concat()方法使用了StringBuilder,concat()的性能应该和StringBuilder的一样好,但是由于额外的创建StringBuilder和做.append(str).append(str).toString()的操作,使得concate的性能会受到一些影响,所以StringBuilder和String Cancate的时间是1.8和3.3。
因此,即时在做最简单的拼接时,如果我们不想创建StringBuffer或StringBuilder实例使,我们也因该使用concat。但是对于大量的字符串拼接操作,我们就不应该使用concat(译者注:因为测试代码功能上并不完全等价,更换后的测试代码concat的平均处理时间是1650.9毫秒。这个结果在原文的评论里面。),因为concat会降低你程序的性能,消耗你的cpu。因此,在不考虑线程安全和同步的情况下,为了获得最高的性能,我们应尽量使用StringBuilder
发表评论
-
国内开源中国镜像settings.xml配置
2015-08-13 11:43 3445mirror <mirror> ... -
Java正确获取星期Calendar.DAY_OF_WEEK
2014-10-17 09:44 42192正确获取星期几(Calendar.DAY_OF_WEE ... -
JAVA开发中数据源创建方法
2014-09-15 11:44 1264数据源是数据库连接池里面的概念,连接池就是指当服务器 ... -
JAVA优秀开源框架收集
2014-08-09 10:05 1689==========Java Core======== * ... -
让DateFormat多线程安全
2014-03-14 18:20 1165"DateFormat 不是同步 ... -
BigInteger类的使用以及计算应该注意的地方
2014-02-25 14:58 3358在java中提供了大数字的操作类,即java.math.B ... -
Java调用Lua脚本(LuaJava使用、安装及Linux安装编译)
2013-11-08 11:09 10986依赖包(附件有下载): 包名类型操作系统luajava-1.1 ... -
Map的高效遍历
2013-05-08 13:40 1181引用场景:偶尔生产环境的某台机器CPU使用率很高,经过定位发现 ... -
Hql查询条件的参数绑定
2013-05-08 13:35 1326Hql查询条件的参数绑定 3. 参数绑定: Hibern ... -
在Eclipse中导入dtd和xsd文件,使XML自动提示
2012-08-14 10:02 4443DTD 类型约束文件 1. Window->Pr ... -
遭遇 Could not initialize class sun.awt.X11GraphicsEnvironment
2012-08-06 10:02 2299一大早来到公司,发现jsp验证码不能显示。查tomcat日志: ... -
ExtJs GridPanel展示Java返回的Date类型数据
2012-07-05 11:23 2419后台Java返回时间对象格式: "lastLogin ... -
【转载】Ibatis (井号)# (美元符号)$ 区别
2012-06-21 14:52 4091Ibatis (井号)# (美元符号)$ 区别 1、#可以进行 ... -
出现Bad version number in .class file这个问题时,要注意三个方面
2012-06-19 17:08 944出现Bad version number in .class ... -
js图片轮换效果 js焦点图代码
2010-11-11 18:08 5218图片轮换效果,在网上有很多了,很多都是fla ... -
java中getResourceAsStream的问题
2010-10-11 11:54 3119在项目使用getResourceAsStream()方法出现了 ... -
在Servlet中获取来源URL
2009-07-30 17:01 9350public void doGet(HttpServletR ...
相关推荐
JAVA的字符串拼接与性能 概述:本文主要研究的是JAVA的字符串拼接的性能,原文中的测试代码在功能上并不等价,导致concat的测试意义不大。不过原作者在评论栏给了新的concat结果,如果有兴趣的同学建议自己修改代码...
总之,理解和掌握Java字符串拼接的性能差异是优化代码的关键。正确选择拼接方法可以帮助我们编写出运行更快、资源消耗更低的程序。在实际开发中,应根据具体情况选择最适合的字符串处理策略,以提高程序的效率和响应...
本文主要探讨了在Java中几种不同的字符串拼接方法的性能差异,包括使用操作符`+`、`String.concat()`、`StringBuffer.append()`和`StringBuilder.append()`。以下是对这些方法的详细分析: 1. **字符串拼接操作符 ...
Java字符串拼接效率测试过程解析 Java字符串拼接效率测试过程解析是Java开发中非常重要的一个话题。字符串拼接是Java开发中最常见的操作之一,但是不同的拼接方式对性能的影响是巨大的。本文主要介绍了Java字符串...
标题中的“SQL2JAVA-java字段串代码拼接小工具”是指一个辅助开发的软件,它主要功能是帮助程序员便捷地在Java代码和SQL语句之间进行转换,特别是处理字符串拼接的问题。在软件开发过程中,尤其是在数据库交互时,...
- `StringBuilder`和`StringBuffer`类:用于大量字符串拼接,线程安全,性能优于`+`。 5. 查找与替换: - `indexOf()`:查找子字符串首次出现的位置。 - `lastIndexOf()`:查找子字符串最后一次出现的位置。 - ...
如果拼接的字符串很多,使用字符串连接符的计算时间和对性能的消耗变得难以估算。 问题原因 主要原因是 String 类的不可变性。当连接两个字符串时,需要创建一个新的字符串对象,导致大量的对象创建和销毁,从而...
本文将深入探讨如何在Java中使用"+"运算符进行字符串拼接,并分析其性能影响及与`StringBuffer`、`StringBuilder`之间的区别。 #### 一、"+"运算符进行字符串拼接 在Java中,可以使用"+"运算符来连接两个或多个...
下面我们将深入探讨Java字符串拼接的原理、性能影响以及编译器的优化策略。 首先,当我们用`+`运算符或`StringBuilder`/`StringBuffer`进行字符串拼接时,由于String的不可变性,每次拼接都会创建新的字符串对象。...
总的来说,`StringBuilder`是Java中处理字符串拼接的关键工具,尤其在需要高效构建长字符串的场景下。它提供了灵活的方法来添加内容,且避免了不必要的内存开销。通过使用`StringBuilder`,开发者可以编写出更高效、...
在本教程中,我们将聚焦于如何将Excel数据批量导入到PostgreSQL数据库,特别关注一种常见的方法——通过字符串拼接的方式。PostgreSQL是一个功能强大的开源关系型数据库管理系统,而Excel则是广泛使用的电子表格工具...
- 使用`StringBuilder`或`StringBuffer`进行字符串拼接和修改,这两个类是线程安全的。 - `append()`: 追加字符串。 - `insert()`: 在指定位置插入字符串。 - `replace()`: 替换部分字符串。 7. **字符串编码与...
在本篇文章中,我们将深入探讨如何使用 Java 编程语言结合 iBatis 框架进行 SQL 字符串的动态拼接。通过分析提供的代码片段,我们可以了解到在实际开发过程中,这种动态 SQL 的构建方式非常常见,尤其是在处理复杂的...
这时,StringBuilder和StringBuffer类就派上用场了,它们提供了可变的字符串操作,适合在循环中进行字符串拼接,性能优于使用"+"运算符。 Java异常处理也是编程中的重要组成部分。在处理字符串相关的问题时,可能会...
而StringBuffer类是可变的,可以使用`append()`方法添加内容,而不必每次都创建新对象,因此在处理大量字符串拼接时,StringBuffer的效率更高。 总结来说,这个实验旨在帮助我们理解和掌握Java中字符串的基本操作,...
在Java中,字符串是一系列字符的集合,与其他编程语言将字符串视为字符数组不同,Java采用了更为先进的方式——将字符串视为`String`类型对象来处理。这种设计使得Java能够提供丰富的字符串处理功能,包括但不限于...
在Java编程中,字符串拼接是一项常见的操作,尤其是在循环中,高效的字符串拼接方式对于程序性能至关重要。在本文中,我们将探讨在`for`循环中如何正确使用字符串拼接,并分析几种常见方法的效率和底层实现。 首先...
在 Java 中,字符串拼接是我们日常开发中经常遇到的一个问题。随着项目的发展和复杂度的增加,字符串拼接的效率变得越来越重要。今天,我们将通过测试和分析,比较 Java 中 5 种不同的字符串拼接方法的效率,并探究...