您的位置:首页 > 编程语言 > Java开发

【Java语言】Java 字符替换效率比较

2012-09-13 12:49 274 查看
public static String encode(String str) {
		if(str == null) {
			return null;
		}
		str = str.replace('+', '~');
		str = str.replace('/', '_');
		str = str.replace('=', '.');
		return str;
	}
	
	public static String encode2(String str) {
		if(str == null) {
			return null;
		}
		str = str.replace("+", "~");
		str = str.replace("/", "_");
		str = str.replace("=", ".");
		return str;
	}
	
	public static String encode3(String str) {
		if(str == null) {
			return null;
		}
		char[] array = str.toCharArray();
		for (int i = 0, length = array.length; i < length; i++) {
			if(array[i] == '+') {
				array[i] = '~';
			} else if(array[i] == '/') {
				array[i] = '_';
			} else if(array[i] == '=') {
				array[i] = '.';
			}
		}
		return new String(array);
	}


写了如上三个方法,3个方法都能达到字符替换的效果,但是效率不一样;第一种、第二种方式都是遍历三遍, 第三种遍历一遍;

测试字符串为:
String str = "asdasddasd+asd/asdadas======asdasd++++++++//===kkkklakdjfh";
执行1000000次,结果为:3031517061401
第三种数组的效率最高啊;

测试字符串为:String str = "asdasddasdasdasddasdasdasddasdasdasddasdasdasddasdasdasddasdasdasddasd";
执行1000000次,结果为:
1169228741496
第一种replace的效率反而高了。
原因是replace方法会先去查找字符串中是否包含需要替换的字符,如果没有就直接返回了,有才会去遍历替换(下面是replace源码,有兴趣的可以看下); 所以当目标字符串中不包含需要替换的字符时,replace效率最高;
在日常开发中,就不要折腾了,直接调用replace来处理即可。

public String replace(char oldChar, char newChar) {
	if (oldChar != newChar) {
	    int len = count;
	    int i = -1;
	    char[] val = value; /* avoid getfield opcode */
	    int off = offset;   /* avoid getfield opcode */

	    while (++i < len) {
		if (val[off + i] == oldChar) {
		    break;
		}
	    }
	    if (i < len) {
		char buf[] = new char[len];
		for (int j = 0 ; j < i ; j++) {
		    buf[j] = val[off+j];
		}
		while (i < len) {
		    char c = val[off + i];
		    buf[i] = (c == oldChar) ? newChar : c;
		    i++;
		}
		return new String(0, len, buf);
	    }
	}
	return this;
    }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: