- 浏览: 298819 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
刘燕宝宝鱼:
fengqiyuanluo 写道q77102902 写道DAO ...
spring事务管理几种方式(转) -
zweichxu:
q77102902 写道DAO层注解加的有问题,不要误导新人, ...
spring事务管理几种方式(转) -
jsolo:
q77102902 写道DAO层注解加的有问题,不要误导新人, ...
spring事务管理几种方式(转) -
fengqiyuanluo:
q77102902 写道DAO层注解加的有问题,不要误导新人, ...
spring事务管理几种方式(转) -
q77102902:
DAO层注解加的有问题,不要误导新人,DAO层注解应该是@Re ...
spring事务管理几种方式(转)
这是我在网上看到的,所以就转载了。大家分享一下http://zhlwish.blog.sohu.com/36470062.html
简要的说, String 类型和 StringBuffer 类型的主要性能区别其实在于 String 是不可变的对象(为什么?问问 Java 的设计者吧,为什么 String 不是原生类型呢?)因此在每次对 String 类型进行改变的时候其实都等同于生成了一个新的 String 对象,然后将指针指向新的 String 对象,所以经常改变内容的字符串最好不要用 String ,因为每次生成对象都会对系统性能产生影响,特别当内存中无引用对象多了以后, JVM 的 GC 就会开始工作,那速度是一定会相当慢的。这里尝试举个不是很恰当的例子:
String S1 = “abc”; For(int I = 0 ; I < 10000 ; I ++) // For 模拟程序的多次调用 { S1 + = “def”; S1 = “abc”; }
如果是这样的话,到这个 for 循环完毕后,如果内存中的对象没有被 GC 清理掉的话,内存中一共有 2 万多个了,惊人的数目,而如果这是一个很多人使用的系统,这样的数目就不算很多了,所以大家使用的时候一定要小心。
而如果是使用 StringBuffer 类则结果就不一样了,每次结果都会对 StringBuffer 对象本身进行操作,而不是生成新的对象,再改变对象引用。所以在一般情况下我们推荐使用 StringBuffer ,特别是字符串对象经常改变的情况下。而在某些特别情况下, String 对象的字符串拼接其实是被 JVM 解释成了 StringBuffer 对象的拼接,所以这些时候 String 对象的速度并不会比 StringBuffer 对象慢,而特别是以下的字符串对象生成中, String 效率是远要比 StringBuffer 快的:
String S1 = “This is only a” + “ simple” + “ test”; StringBuffer Sb = new StringBuilder(“This is only a”).append(“ simple”).append(“ test”);
你会很惊讶的发现,生成 String S1 对象的速度简直太快了,而这个时候 StringBuffer 居然速度上根本一点都不占优势。其实这是 JVM 的一个把戏,在 JVM 眼里,这个String S1 = “This is only a” + “ simple” + “test”; 其实就是: String S1 = “This is only a simple test”; 所以当然不需要太多的时间了。但大家这里要注意的是,如果你的字符串是来自另外的 String 对象的话,速度就没那么快了,譬如:
String S2 = “This is only a”; String S3 = “ simple”; String S4 = “ test”; String S1 = S2 +S3 + S4;
这时候 JVM 会规规矩矩的按照原来的方式去做, S1 对象的生成速度就不像刚才那么快了,一会儿我们可以来个测试作个验证。
由此我们得到第一步结论: 在大部分情况下 StringBuffer > String
而 StringBuilder 跟他们比又怎么样呢?先简单介绍一下, StringBuilder 是 JDK5.0 中新增加的一个类,它跟 StringBuffer 的区别看下面的介绍(来源 JavaWorld ):
Java.lang.StringBuffer 线程安全的可变字符序列。类似于 String 的字符串缓冲区,但不能修改。可将字符串缓冲区安全地用于多个线程。可以在必要时对这些方法进行同步,因此任意特定实例上的所有操作就好像是以串行顺序发生的,该顺序与所涉及的每个线程进行的方法调用顺序一致。
每个字符串缓冲区都有一定的容量。只要字符串缓冲区所包含的字符序列的长度没有超出此容量,就无需分配新的内部缓冲区数组。如果内部缓冲区溢出,则此容量自动增大。从 JDK 5.0 开始,为该类增添了一个单个线程使用的等价类,即 StringBuilder 。与该类相比,通常应该优先使用 StringBuilder 类,因为它支持所有相同的操作,但由于它不执行同步,所以速度更快。
但是如果将 StringBuilder 的实例用于多个线程是不安全的。需要这样的同步,则建议使用 StringBuffer 。
这样说估计大家都能明白他们之间的区别了,那么下面我们再做一个一般性推导:
在大部分情况下 StringBuilder > StringBuffer
因此,根据这个不等式的传递定理: 在大部分情况下 StringBuilder > StringBuffer > String
既然有这样的推导结果了,我们做个测试验证一下:
测试代码如下:
public class StringTest { /** Creates a new instance of StringTest */ final static int ttime = 70000;// 测试循环次数 public void testString(String s) { long begin = System.currentTimeMillis(); for (int i = 0; i < ttime; i++) { s += "add"; } long over = System.currentTimeMillis(); System.out.println(" 操作 " + s.getClass().getName() + " 类型使用的时间为: " + (over - begin) + " 毫秒 "); } public void testStringBuffer(StringBuffer s) { long begin = System.currentTimeMillis(); for (int i = 0; i < ttime; i++) { s.append("add"); } long over = System.currentTimeMillis(); System.out.println(" 操作 " + s.getClass().getName() + " 类型使用的时间为: " + (over - begin) + " 毫秒 "); } public void testStringBuilder(StringBuilder s) { long begin = System.currentTimeMillis(); for (int i = 0; i < ttime; i++) { s.append("add"); } long over = System.currentTimeMillis(); System.out.println(" 操作 " + s.getClass().getName() + " 类型使用的时间为: " + (over - begin) + " 毫秒 "); } // 对 String 直接进行字符串拼接的测试 public void testString1() { String s2 = "abadf"; long begin = System.currentTimeMillis(); for (int i = 0; i < ttime; i++) { String s = s2 + s2 + s2; } long over = System.currentTimeMillis(); System.out.println(" 操作字符串对象引用相加类型使用的时间为: " + (over - begin) + " 毫秒 "); } public void testString2() { long begin = System.currentTimeMillis(); for (int i = 0; i < ttime; i++) { String s = "abadf" + "abadf" + "abadf"; } long over = System.currentTimeMillis(); System.out.println(" 操作字符串相加使用的时间为: " + (over - begin) + " 毫秒 "); } public static void main(String[] args) { String s1 = "abc"; StringBuffer sb1 = new StringBuffer("abc"); StringBuilder sb2 = new StringBuilder("abc"); StringTest t = new StringTest(); t.testString(s1); t.testStringBuffer(sb1); t.testStringBuilder(sb2); t.testString1(); t.testString2(); } }
以上代码在 NetBeans 5.0 IDE/JDK1.6 上编译通过,循环次数 ttime 为 10000 次的测试结果如下:
操作 java.lang.String 类型使用的时间为: 4392 毫秒
操作 java.lang.StringBuffer 类型使用的时间为: 0 毫秒
操作 java.lang.StringBuilder 类型使用的时间为: 0 毫秒
操作字符串对象引用相加类型使用的时间为: 15 毫秒
操作字符串相加使用的时间为: 0 毫秒
好像还看不出 StringBuffer 和 StringBuilder 的区别,把 ttime 加到 30000 次看看:
操作 java.lang.String 类型使用的时间为: 53444 毫秒
操作 java.lang.StringBuffer 类型使用的时间为: 15 毫秒
操作 java.lang.StringBuilder 类型使用的时间为: 15 毫秒
操作字符串对象引用相加类型使用的时间为: 31 毫秒
操作字符串相加使用的时间为: 0 毫秒
StringBuffer 和 StringBuilder 的性能上还是没有太大的差异,再加大到 100000 看看,这里就不加入对 String 类型的测试了,因为对 String 类型这么大数据量的测试会很慢滴……
操作 java.lang.StringBuffer 类型使用的时间为: 31 毫秒
操作 java.lang.StringBuilder 类型使用的时间为: 16 毫秒
能看出差别了,但其中有多次的测试结果居然是 StringBuilder比 StringBuffer 快,再加大一些到 1000000 看看(应该不会当机吧?):
操作 java.lang.StringBuffer 类型使用的时间为: 265 毫秒
操作 java.lang.StringBuilder 类型使用的时间为: 219 毫秒
有些少区别了,而且结果很稳定,再大点看看, ttime = 5000000 :
······ Exception in thread "main" java.lang.OutOfMemoryError: Java heap space ······
呵呵,算了,不去测试了,基本来说都是在性能上都是 StringBuilder > StringBuffer > String 的了。
其实我这里测试并不是很准确,因为都放在了一起以先后顺序进行,测试方法中间没有考虑到JVM的GC收集前面产生的无引用对象垃圾而对执行过程的中断时间。如果大家有更好的想法或者思路欢迎跟我讨论:chenpengyi#gmail.com。
发表评论
-
Lucene 入门
2011-05-29 15:13 0http://blog.csdn.net/wenlin56/c ... -
java Transient
2011-01-08 23:10 1791我们都知道一个对象只 ... -
谈谈java与js中的&&、& ||、|
2010-05-06 23:31 2959java中的逻辑运算符主要 ... -
Java中接口里定义的成员变量
2010-04-18 22:45 2563在interface里面的变量都 ... -
值得理解的Java多态性
2010-04-16 22:13 1171在网上想搜一下关于java多态的一些个人理解,最好是一些通俗易 ... -
Java 1.5和1.6中新特性(转)
2010-04-14 22:43 1125JDK5新特性(与1.4相比)【转】 1 循环 for ... -
JVM运行java程序在内存中的分配
2010-04-14 15:59 2185第一个JVM诞生于1995年。 JVM的主要任务是:装载cla ... -
代理模式与Java 动态代理类
2010-04-05 23:09 34261. 代理模式 代理模式的作用是:为其他对象提供一种代理以控制 ... -
关于类加载器的一个应用测试
2010-04-05 22:33 1208新建一个web项目然后新建一个servlet,在servet的 ... -
Java 类加载器文章
2010-04-05 00:31 988本文源于:深入探讨 Jav ... -
java 泛型
2010-04-04 19:34 1760一、泛型的基本入门 泛型(Generic type 或者gen ... -
java annotation 注解整理(部分转载)
2010-04-04 00:05 1512本文将向你介绍J2SE5.0中的新特性之一:注释(注解)。本文 ... -
正则表达式(收藏)
2010-04-03 23:02 8911、非负整数:^\d+$ 2、 ... -
JavaBean 的简单内省(Intorspector)操作及BeanUtils工具类
2010-04-03 19:45 14741、对Javabean的简单的内省操作 问题 已知一个Refl ... -
Java异常的文章(转载)
2010-04-03 16:12 1163六种异常处理的陋习 ... -
Java编码规范(The Elements of Java Style)
2010-04-03 12:28 3606Genaral Principles 一般约定 1.Adher ... -
JavaBean的命名规则
2010-04-03 12:26 8621前段时间,写程序时, ... -
equals()和hashCode()详细分析(转载)
2010-03-29 22:25 1073HashCode是地址与哈西算 ... -
equals()和hashCode()详细分析(转载)
2010-03-29 22:18 996HashCode是地址与哈西算 ... -
hashcode、 equals & ==
2010-03-29 22:17 12521.如果是基本变量,没有hashcode和equals方法,基 ...
相关推荐
在这篇文章中,我们将从源码角度对String、StringBuffer和StringBuilder进行深入分析,了解它们之间的区别。 String类 String类是Java中最基本的字符串类,它是final类,意思是它不能被继承。String类的字符串是不...
对于Java中的字符串操作,主要涉及到三个类:String、StringBuffer和StringBuilder。理解这三个类之间的区别,对于编写高质量、高效率的代码至关重要。 首先,String类是Java中最基础也是最常用的字符串处理类。...
StringBuffer:字符创变量 StringBuilder:字符创变量 从上面的名字可以看到,String是“字符创常量”,也就是不可改变的对象。对于这句话的理解你可能会产生这样一个疑问 ,比如这段代码:
在 Java 中,String, StringBuffer 和 StringBuilder 三个类都是用于字符操作的,但它们之间有着很大的区别。 首先,String 是不可变类,意味着一旦创建了 String 对象,就不能修改它的值。每次对 String 对象的...
String、StringBuffer 和 StringBuilder 是 Java 语言中三种不同类型的字符串处理方式,它们之间存在着明显的性能和线程安全性差异。 String String 类型是不可变的对象,每次对 String 对象进行改变时都会生成一...
在Java编程语言中,`String`、`StringBuffer`和`StringBuilder`是处理字符串的三个重要类,它们各自有特定的使用场景和优缺点。理解它们的差异对于编写高效的代码至关重要。 **String类** `String`是不可变的类,...
在Java编程语言中,`String`、`StringBuffer`和`StringBuilder`都是用来处理字符串的类,但它们之间存在显著的差异,主要体现在性能、线程安全性和使用场景上。 首先,`String`是最基本的字符串类,它代表的是不可...
在Java编程语言中,String、StringBuilder和StringBuffer都是用来处理字符串的类,它们之间存在一些重要的区别,主要涉及到性能和线程安全性。 首先,`String`类代表的是字符串常量,一旦创建,其内容就不能改变。...
string,stringbuffer,stringbuilder
在Java编程语言中,String、StringBuffer和StringBuilder都是用来处理字符串的重要类,它们各自有特定的使用场景和特性。理解这三个类的区别对于任何Java开发者,无论是初学者还是经验丰富的程序员,都是非常重要的...
最后,让我们总结一下 Java 中 String, StringBuffer 与 StringBuilder 三种字符串类型的区别和用法。String 类型是不可变的对象,性能不好,适合不需要修改的字符串对象。StringBuffer 类型是可变的对象,性能好,...
string,stringBuffer,stringBuilder
在Java编程语言中,String、StringBuffer和StringBuilder都是用来处理字符串的重要类,它们各自具有不同的特性和使用场景。下面将详细解析这三个类的区别。 首先,`String`类是最基础的字符串处理类,它被设计为不...
stringbuilder用法 String、StringBuilder、StringBuffer 用法比较String、StringBuilder、StringBuffer 用法比较String、StringBuilder、StringBuffer 用法比较String、StringBuilder、StringBuffer 用法比较String...
在Java编程语言中,String、StringBuffer和StringBuilder都是用来处理字符串的对象,但它们之间存在显著的区别。String是最常见的字符串类型,它的特点是不可变性。这意味着一旦一个String对象被创建,就不能进行...
Java 中 String、StringBuffer 和 StringBuilder 是三个常用的字符串操作类,了解它们之间的区别对 Java 开发者来说非常重要。本文将详细介绍这三者的区别、用法及各自的优缺点。 String String 是 Java 中最基本...
总结来说,StringBuffer和StringBuilder在处理可变字符串时提供了便利,但它们之间存在关键差异:StringBuffer适合多线程环境,因为它提供了线程安全的操作;而StringBuilder则适用于单线程环境,它的操作速度较快。...
BATJ面试题讲解-String、StringBuffer、StringBuilder的区别
Java面试题-每日一题:String、StringBuffer、StringBuilder的区别
在Java编程语言中,String、StringBuffer和StringBuilder都是用来处理字符串的类,但它们之间存在显著的性能和功能差异。下面我们将深入探讨这三个类的区别。 首先,`String`类是Java中最基本的字符串类型,它表示...