- 时间:2021-08-30 08:57 编辑: 来源: 阅读:
- 扫一扫,手机访问
摘要:java字符串抉择
下面我们就字符串连接方面分析。
[b] 1.String[/b]
打开String的源码,如图所示
[img]http://files.jb51.net/file_images/article/201612/20161223171339735.png?20161123171349[/img]
会发现存储字符串的字符数值是final常量。再看String的构造方法,发现String的value值在构造方法就确定了值。这里有必要说明下关键字final
final修饰的属性为常量(值不可改变),要么在声明的同时赋值,要么在构造方法里面进行赋值,一旦赋值就不能改变。
所以,用String来实现字符串拼接,由于String的值不可改变,所以每次拼接都要生成一个新的String来存储新的字符串。所以使用String来处理字符串拼接性能会很低。
更多String的信息,可以参考博客:[url=http://longpo.iteye.com/blog/2199493]http://longpo.iteye.com/blog/2199493[/url]
[b] 2.StringBuffer[/b]
StringBuffer类继承了抽象类 AbstractStringBuilder类,打开AbstractStringBuilder源码
[img]http://files.jb51.net/file_images/article/201612/20161223171411132.png?20161123171420[/img]
再来StringBuffer看看重载的三个构造方法
[img]http://files.jb51.net/file_images/article/201612/20161223171444343.png?20161123171455[/img]
发现都是调用父类AbstractStringBuilder的构造方法
[img]http://files.jb51.net/file_images/article/201612/20161223171510276.png?20161123171530[/img]
发现StringBuffer的存储数据的char数组不是final类型的,说明可以变更,且构建出来的字符串都还有空余的位置来拼接字符串。
在StringBuffer中我们使用append()函数来进行字符串的拼接。我们可以想到虽然char数组还有剩余,但一直拼接肯定也不够用。所以有必要看看append函数的源码实现。
[img]http://files.jb51.net/file_images/article/201612/20161223171541893.png?2016112317162[/img]
查看其父类AbstractStringBuilder的append方法
[img]http://files.jb51.net/file_images/article/201612/20161223171613485.png?20161123171635[/img]
发现当value数组容量不够时,会创建一个新的value数组来存储字符串。到这里就应该明白了StringBuffer字符串拼接的原理啦。当char value数组不够时会创建个更大容量的数组来存储。效率明显比String高。
[b]3.StringBuilder[/b]
StringBuilder和StringBuffer是两兄弟,用法基本一样,不同的是StringBuffer是同步的,线程安全的,而StringBuilder不保证同步,线程不安全。
[img]http://files.jb51.net/file_images/article/201612/20161223171706479.png?20161123171716[/img]
StringBuilder在大多数实现中比StringBuffer快, 在字符串缓冲区被单个线程访问时,建议优先使用StringBuilder
以上所述是小编给大家介绍的java字符串抉择,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!