String的使用陷阱

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Caiaixiong/article/details/85038457

String一经初始化后,就不会再改变其内容,对String字符串的操作实际上是对其副本的操作,原来的字符串一点改变都没有。例如:

String str = "a";
str = str + "b";

实际上“a”字符串对象已经丢弃,现在又产生了另一个字符串str+“b”,如果多次执行这些改变字符串内容的操作,会导致大量的副本存留在内存中,降低效率。
相反,StringBuilder和StringBuffer是对原字符串本身进行操作的,可以对字符串进行修改而不产生副本。效率测试如下:

package com.cax.test;

public class TestStringBuilder {
	public static void main(String[] args) {
		//使用String进行字符串的拼接
		String str1 = "";
		long num1 = Runtime.getRuntime().freeMemory();//获取系统剩余内存空间
		long time1 = System.currentTimeMillis(); //获取系统的当前时间
		for (int i = 0; i < 5000; i++) {
			str1 = str1+i;
		}
		long num2 = Runtime.getRuntime().freeMemory();//获取系统剩余内存空间
		long time2 = System.currentTimeMillis(); //获取系统的当前时间
		System.out.println("String占用内存:"+(num1-num2));
		System.out.println("String占用时间:"+(time2-time1));
		
		//使用StringBuilder进行字符串拼接
		StringBuilder str2 = new StringBuilder("");
		long num3 = Runtime.getRuntime().freeMemory();//获取系统剩余内存空间
		long time3 = System.currentTimeMillis(); //获取系统的当前时间
		for (int i = 0; i < 5000; i++) {
			str2.append(i);
			
		}
		long num4 = Runtime.getRuntime().freeMemory();//获取系统剩余内存空间
		long time4 = System.currentTimeMillis(); //获取系统的当前时间
		System.out.println("String占用内存:"+(num3-num4));
		System.out.println("String占用时间:"+(time4-time3));
	}
}

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/Caiaixiong/article/details/85038457
今日推荐