字符串的拼接(StringBuilder)

package test;

/**
 * 测试可变字符序列和不可变字符序列使用的陷阱
 * @author 
 *
 */
public class TestStringBuilder {
	public static void main(String[] args) {
		
		//遇到循环累加 一定要使用  StringBuilder
		
		/** 使用String进行字符串的拼接*/
		String str = "";
		//本质上是使用了StringBuilder的字符串拼接,但是每次循环都会生成一个StringBuilder对象
		long num1 = Runtime.getRuntime().freeMemory();//获取系统剩余内存空间
		long time1 = System.currentTimeMillis();//获取系统当前时间
		for(int i=0; i<5000; i++){
			str = str +i;//相等于产生了10000个对象
		}
		long num2 = Runtime.getRuntime().freeMemory();
		long time2 = System.currentTimeMillis();
		System.out.println("String占用内存:"+(num1-num2));
		System.out.println("String占用时间:"+(time2-time1));
		
		
		
		/** 使用StringBuilder进行字符串的拼接*/
		StringBuilder sb = new StringBuilder("");
		long num3 = Runtime.getRuntime().freeMemory();
		long time3 = System.currentTimeMillis();
		for(int i=0; i<5000; i++){
			sb.append(i);
		}
		long num4 = Runtime.getRuntime().freeMemory();
		long time4 = System.currentTimeMillis();
		System.out.println("StringBuilder占用内存:"+(num3-num4));
		System.out.println("StringBuilder占用时间:"+(time4-time3));
		
		
	}
}

你可能感兴趣的:(字符串的拼接(StringBuilder))