String StringBuffer StringBuilder 原理解析ITeye - 凯发娱乐

String StringBuffer StringBuilder 原理解析ITeye

2019年02月24日14时16分22秒 | 作者: 书雁 | 标签: 目标,字符串,运用 | 浏览: 1120

比如:StringBuffer str= new StringBuffer("You are nice."); 
str.append("I love you so much."); 

String str="You are nice."; 
str+="I love you so much."; 


众所都知,功能StringBuiler StringBuffer String,
原理 StringBuiler 对错线程安全的,

StringBuffer 线程安全的,所以组装的时分会加锁 ,程序将只发生两个目标:开始的
StringBuffer和拼接时的String("I love you so much.")."),也不再需求创立暂时的StringBuffer类目标然后还得将其转化回String目标。

String 会创立1个暂时StringBuffer,一起为两个字符串创立String,最终还要将StringBuffer转化为String 进行赋值(创立一个String)

原文:
在用String类目标直接拼接时,JVM会创立一个暂时的StringBuffer类目标,并调用其append()办法完结字符串的拼接,这是由于 String类是不可变的,拼接操作不得不运用StringBuffer类(而且--JVM会将"You are nice."和"I love you so much."创立为两个新的String目标)。之后,再将这个暂时StringBuffer目标转型为一个String,价值不菲!可见,在这一个简略 的一次拼接过程中,咱们让程序创立了四个目标:两个待拼接的String,一个暂时StringBuffer,和最终将StringBuffer转型成为 的String--它当然不是开始的str了,这个引证的称号没变,但它指向了新的String目标。

而假如直接运用StringBuffer类,程序将只发生两个目标:开始的StringBuffer和拼接时的String("I love you so much."),也不再需求创立暂时的StringBuffer类目标然后还得将其转化回String目标。

能够幻想,当咱们的字符串要被循环拼接若干段时,用String类直接操作会带来多少额定的体系开支,生成多少无用的暂时StringBuffer 目标,并处理多少次无谓的强制类型转化哪。

测试用例:


public class StringTest {

public static void main(String[] args){
Long t1 = (new java.util.Date()).getTime();
String str1 ="";
for(int i=0;i 10000;i++){
str1 = str1+i;
}
Long t2 = (new java.util.Date()).getTime();
StringBuffer str2 = new StringBuffer();
for(int i=0;i 100000;i++){
str2.append(i);
}
Long t3 = (new java.util.Date()).getTime();
StringBuffer str3 = new StringBuffer(100000);
for(int i=0;i 100000;i++){
str3.append(i);
}
Long t4 = (new java.util.Date()).getTime();

StringBuilder str4 = new StringBuilder();
for(int i=0;i 100000;i++){
str4.append(i);
}
Long t5 = (new java.util.Date()).getTime();

StringBuilder str5 = new StringBuilder(100000);
for(int i=0;i 100000;i++){
str5.append(i);
}
Long t6 = (new java.util.Date()).getTime();

System.out.println("String 1万条:"+(t2-t1));
System.out.println("StringBuffer2 10万条:"+(t3-t2));
System.out.println("StringBuffer3 10万条:"+(t4-t3));

System.out.println("StringBuilder4 10万条:"+(t5-t4));
System.out.println("StringBuilder5 10万条:"+(t6-t5));
}

}

String 1万条:380 毫秒
StringBuffer2 10万条:13 毫秒
StringBuffer3 10万条:8 毫秒
StringBuilder4 10万条:10 毫秒
StringBuilder5 10万条:5毫秒

定论: 运用StringBuffer 而且不给初始值,是最简略的,功能不同不大
组装字符串,运用常见办法
StringBuffer str2 = new StringBuffer();
版权声明
本文来源于网络,版权归原作者所有,其内容与观点不代表凯发娱乐立场。转载文章仅为传播更有价值的信息,如采编人员采编有误或者版权原因,请与我们联系,我们核实后立即修改或删除。

猜您喜欢的文章