java字符串抉择
2016-08-15 00:00
134 查看
摘要: final修饰的属性为常量(值不可改变),要么在声明的同时赋值,要么在构造方法里面进行赋值,一旦赋值就不能改变。
下面我们就字符串连接方面分析。
1.String
打开String的源码,如图所示
![](http://img.mp.itc.cn/upload/20160418/2ce69376a8f74098b7b1889e9508b1e2.jpg)
会发现存储字符串的字符数值是final常量。再看String的构造方法,发现String的value值在构造方法就确定了值。这里有必要说明下关键字final
final修饰的属性为常量(值不可改变),要么在声明的同时赋值,要么在构造方法里面进行赋值,一旦赋值就不能改变。
所以,用String来实现字符串拼接,由于String的值不可改变,所以每次拼接都要生成一个新的String来存储新的字符串。所以使用String来处理字符串拼接性能会很低。
更多String的信息,可以参考博客:http://longpo.iteye.com/blog/2199493
2.StringBuffer
StringBuffer类继承了抽象类 AbstractStringBuilder类,打开AbstractStringBuilder源码
![](http://img.mp.itc.cn/upload/20160418/894e67e8b35e430a9c7c826871fa9a24.jpg)
再来StringBuffer看看重载的三个构造方法
![](http://img.mp.itc.cn/upload/20160418/c08bf818876d4192b4bf6271023a6350.jpg)
![](http://img.mp.itc.cn/upload/20160418/6de09a84f4724bc880b0942cff4a265d_th.jpg)
发现都是调用父类AbstractStringBuilder的构造方法
![](http://img.mp.itc.cn/upload/20160418/6f95881456c549deaabeef81799980bf.jpg)
发现StringBuffer的存储数据的char数组不是final类型的,说明可以变更,且构建出来的字符串都还有空余的位置来拼接字符串。
在StringBuffer中我们使用append()函数来进行字符串的拼接。我们可以想到虽然char数组还有剩余,但一直拼接肯定也不够用。所以有必要看看append函数的源码实现。
![](http://img.mp.itc.cn/upload/20160418/f76973feca3b430f87ff81005c272a8a.jpg)
查看其父类AbstractStringBuilder的append方法
![](http://img.mp.itc.cn/upload/20160418/a7114d7a49c547d2a54e6782f07dd33f.jpg)
![](http://img.mp.itc.cn/upload/20160418/9a6f011d1f834320894037d2a281cb1c_th.jpg)
发现当value数组容量不够时,会创建一个新的value数组来存储字符串。到这里就应该明白了StringBuffer字符串拼接的原理啦。当char value数组不够时会创建个更大容量的数组来存储。效率明显比String高。
3.StringBuilder
StringBuilder和StringBuffer是两兄弟,用法基本一样,不同的是StringBuffer是同步的,线程安全的,而StringBuilder不保证同步,线程不安全。
![](http://img.mp.itc.cn/upload/20160418/7e2918fa63094c779ab1cad54f1c8a6b.jpg)
![](http://img.mp.itc.cn/upload/20160418/7cb3784aefac49a08bf369afb0c1edb7.jpg)
StringBuilder在大多数实现中比StringBuffer快, 在字符串缓冲区被单个线程访问时,建议优先使用StringBuilder
技术分享:凯哥学堂
下面我们就字符串连接方面分析。
1.String
打开String的源码,如图所示
![](http://img.mp.itc.cn/upload/20160418/2ce69376a8f74098b7b1889e9508b1e2.jpg)
会发现存储字符串的字符数值是final常量。再看String的构造方法,发现String的value值在构造方法就确定了值。这里有必要说明下关键字final
final修饰的属性为常量(值不可改变),要么在声明的同时赋值,要么在构造方法里面进行赋值,一旦赋值就不能改变。
所以,用String来实现字符串拼接,由于String的值不可改变,所以每次拼接都要生成一个新的String来存储新的字符串。所以使用String来处理字符串拼接性能会很低。
更多String的信息,可以参考博客:http://longpo.iteye.com/blog/2199493
2.StringBuffer
StringBuffer类继承了抽象类 AbstractStringBuilder类,打开AbstractStringBuilder源码
![](http://img.mp.itc.cn/upload/20160418/894e67e8b35e430a9c7c826871fa9a24.jpg)
再来StringBuffer看看重载的三个构造方法
![](http://img.mp.itc.cn/upload/20160418/c08bf818876d4192b4bf6271023a6350.jpg)
![](http://img.mp.itc.cn/upload/20160418/6de09a84f4724bc880b0942cff4a265d_th.jpg)
发现都是调用父类AbstractStringBuilder的构造方法
![](http://img.mp.itc.cn/upload/20160418/6f95881456c549deaabeef81799980bf.jpg)
发现StringBuffer的存储数据的char数组不是final类型的,说明可以变更,且构建出来的字符串都还有空余的位置来拼接字符串。
在StringBuffer中我们使用append()函数来进行字符串的拼接。我们可以想到虽然char数组还有剩余,但一直拼接肯定也不够用。所以有必要看看append函数的源码实现。
![](http://img.mp.itc.cn/upload/20160418/f76973feca3b430f87ff81005c272a8a.jpg)
查看其父类AbstractStringBuilder的append方法
![](http://img.mp.itc.cn/upload/20160418/a7114d7a49c547d2a54e6782f07dd33f.jpg)
![](http://img.mp.itc.cn/upload/20160418/9a6f011d1f834320894037d2a281cb1c_th.jpg)
发现当value数组容量不够时,会创建一个新的value数组来存储字符串。到这里就应该明白了StringBuffer字符串拼接的原理啦。当char value数组不够时会创建个更大容量的数组来存储。效率明显比String高。
3.StringBuilder
StringBuilder和StringBuffer是两兄弟,用法基本一样,不同的是StringBuffer是同步的,线程安全的,而StringBuilder不保证同步,线程不安全。
![](http://img.mp.itc.cn/upload/20160418/7e2918fa63094c779ab1cad54f1c8a6b.jpg)
![](http://img.mp.itc.cn/upload/20160418/7cb3784aefac49a08bf369afb0c1edb7.jpg)
StringBuilder在大多数实现中比StringBuffer快, 在字符串缓冲区被单个线程访问时,建议优先使用StringBuilder
技术分享:凯哥学堂
相关文章推荐
- java字符串抉择
- 字符串转换 java
- A Boolean wrapped with string (如何将布尔变量转换为字符串变量--写给java初学者)
- java 面试中的一道编写一个截取字符串的函数!!!!
- java 面试中的一道编写一个截取字符串的函数
- Java中字符串的截取
- [Java]学习Java(3)数组、字符串
- 如何运用java来校验一段字符串是否为汉字
- JAVA-字符串处理中的重点
- Java中的字符串比较
- JAVA与C++::关于JNI中文字符串操作问题总结
- 在某个文件中搜索指定的字符串的java方法
- Java与C之间通过JNI传递中文字符串及乱码问题
- 如何运用java来校验一段字符串是否为汉字
- JAVA-字符串处理中的重点
- enoeht的Java源码系列(5)--字符串加解密
- java中一个float型数据转字符串
- 改进JAVA字符串分解的方法
- 判断java的字符串是否为整数
- JAVA查询一个字符串中字符是不是有汉字