`
darrendu
  • 浏览: 194381 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

04_字符串连接

阅读更多

1.字符串连接操作符"+",不适合用在大规模字符串连接场合,由于字符串不可变,2个字符串连接在一起时,它们内容都要被拷贝。

 

测试代码:

public class _51StringConcatenation {
	private static final int NUM_ITEMS = 5000;
	private static final String LINE_FOR_ITEM = "DJLKFLDLJKFKJLDKJFKJDKFLKDLKL" +
			"LKJFLKDLKFLKJDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDDLKKFDFDJFKLKLDFDFKDF";
	
	
	
	
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		statement();
		statement2();
		String result = statement3();
		System.out.println(NUM_ITEMS*LINE_FOR_ITEM.length() == result.length());
	}
	
	
	private static String statement(){
		String result = "";
		long start = System.currentTimeMillis();
		
		for(int i=0;i<NUM_ITEMS;i++){
			result += LINE_FOR_ITEM;
		}
		
		System.out.println("String concatention Using Time:"+(System.currentTimeMillis() - start));
		return result;
	}
	
	private static String statement2(){
		StringBuilder result = new StringBuilder();
		long start = System.currentTimeMillis();
		
		for(int i=0;i<NUM_ITEMS;i++){
			result.append(LINE_FOR_ITEM);
		}
		
		System.out.println("String Builder Using Time:"+(System.currentTimeMillis() - start));
		return result.toString();
	}
	
	
	private static String statement3(){
		StringBuilder result = new StringBuilder(NUM_ITEMS*LINE_FOR_ITEM.length());
		long start = System.currentTimeMillis();
		
		for(int i=0;i<NUM_ITEMS;i++){
			result.append(LINE_FOR_ITEM);
		}
		
		System.out.println("String Builder When Allocat Size Using Time:"+(System.currentTimeMillis() - start));
		return result.toString();
	}


}

  打印结果:

 

String concatention Using Time:35172

String Builder Using Time:47

String Builder When Allocat Size Using Time:0

true


具有初始大小StringBuilder性能最好,其次StringBuilder,“+”号连接最差,

测试jdk1.6测试,jdk1.6在编译时,已经把"+"号连接转换成StringBuilder,不知道为何性能还是这么差

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics