`
hm4123660
  • 浏览: 278460 次
  • 性别: Icon_minigender_1
  • 来自: 广州
博客专栏
Dea4ce76-f328-3ab2-b24a-fb268e1eeb75
数据结构
浏览量:69082
社区版块
存档分类
最新评论

String,StringBuffer和StringBuilder区别

    博客分类:
  • Java
阅读更多

 

         在实际开发中,我们会经常使用到字符串连接的操作,以前我习惯喜欢用String的‘+’来操作,觉得非常方便好用,最近认真学习了String,StringBuffer和StringBuilder这三个类,才发现使用String来连接字符串,代码性能会很低。下面我们就字符串连接来分析这三种方式。

 

 1.String

        

    打开String的源码,如图所示



 

     会发现存储字符串的字符数值是final常量。再看String的构造方法,发现String的value值在构造方法就确定了值。这里有必要说明下关键字final

     final修饰的属性为常量(值不可改变),要么在声明的同时赋值,要么在构造方法里面进行赋值,一旦赋值就不能改变。

 

    所以,用String来实现字符串拼接,由于String的值不可改变,所以每次拼接都要生成一个新的String来存储新的字符串。所以使用String来处理字符串拼接性能会很低。

   更多String的信息,可以参考博客:http://longpo.iteye.com/blog/2199493

 

2.StringBuffer 

      StringBuffer类继承了抽象类 AbstractStringBuilder类,打开AbstractStringBuilder源码



 

再来StringBuffer看看重载的三个构造方法



 

 

 

发现都是调用父类AbstractStringBuilder的构造方法



 

     发现StringBuffer的存储数据的char数组不是final类型的,说明可以变更,且构建出来的字符串都还有空余的位置来拼接字符串。

 

       在StringBuffer中我们使用append()函数来进行字符串的拼接。我们可以想到虽然char数组还有剩余,但一直拼接肯定也不够用。所以有必要看看append函数的源码实现。

 

 

 查看其父类AbstractStringBuilder的append方法

 

 

 

 

 

  发现当value数组容量不够时,会创建一个新的value数组来存储字符串。到这里就应该明白了StringBuffer字符串拼接的原理啦。当char value数组不够时会创建个更大容量的数组来存储。效率明显比String高。

 

3.StringBuilder

       StringBuilder和StringBuffer是两兄弟,用法基本一样,不同的是StringBuffer是同步的,线程安全的,而StringBuilder不保证同步,线程不安全。

 

 



 

    StringBuilder在大多数实现中比StringBuffer快, 在字符串缓冲区被单个线程访问时,建议优先使用StringBuilder

  • 大小: 9.3 KB
  • 大小: 6.2 KB
  • 大小: 4.9 KB
  • 大小: 16.6 KB
  • 大小: 5.7 KB
  • 大小: 4.1 KB
  • 大小: 9.9 KB
  • 大小: 70.3 KB
  • 大小: 3.5 KB
  • 大小: 4 KB
5
4
分享到:
评论
2 楼 fggsgigomkg 2015-04-10  

1 楼 huangmin001 2015-04-10  
对于常量的相加,只会生成新的常量放入常量池中,因此常量相加效率比stringBudilder要快。

相关推荐

Global site tag (gtag.js) - Google Analytics