jdk8环境下,java字符串使用replace()和replaceAll()方法性能对比
一、背景最近工作中碰到了将数据库表中数据导出csv文件时,对字段数据含有特殊字符导出时清洗点,使得导出的csv文件所有字段都更加干净,比如在数据库中存的一个字段为下面这样的。[\"2018-08-15VKCz\", \"2018-08-15VKCz\",\"2018-08-15VKCz\"]导出时就需要转换为下面这样的,显得数据干净整洁,可以看出只需要将【】“等特殊字符替换成空就可以了,这就需要用
·
一、背景
最近工作中碰到了将数据库表中数据导出csv文件时,对字段数据含有特殊字符导出时清洗点,使得导出的csv文件所有字段都更加干净,比如在数据库中存的一个字段为下面这样的。
[\"2018-08-15VKCz\", \"2018-08-15VKCz\",\"2018-08-15VKCz\"]
导出时就需要转换为下面这样的,显得数据干净整洁,可以看出只需要将【】“等特殊字符替换成空就可以了,这就需要用到replace方法或者replaceAll方法,对于从数据库导出数据,会有巨量数据导出,性能会比较重要,假如会有50万个需要转换,现在就来看看性能如何。
2018-08-15VKCz, 2018-08-15VKCz,2018-08-15VKCz
二、性能比较
1、使用replace方法进行转换,代码如下:
String a = "[\"2018-08-15VKCz\", \"2018-08-15VKCz\",\"2018-08-15VKCz\"]";
final long start1 = System.currentTimeMillis();
for (int i = 0; i < 5000000; i++) {
String replace = a.replace("\"", "")
.replace("[", "")
.replace("]", "");
if (i == 20000) {
System.out.println("使用replace()结果: " + replace);
}
}
long end1 = System.currentTimeMillis();
long result1 = end1 - start1;
System.out.println("使用replace()耗时 :" + result1);
结果如下:
使用replace()结果: 2018-08-15VKCz, 2018-08-15VKCz,2018-08-15VKCz
使用replace()耗时 :3688
2、使用replaceAll方法进行转换,代码如下:
long start = System.currentTimeMillis();
for (int i = 0; i < 500000; i++) {
String replace = a.replaceAll("[(\")|(\\[)|(\\])]", "");
if (i == 20000) {
System.out.println("使用replaceAll()结果:" + replace);
}
}
long end = System.currentTimeMillis();
long result = end - start;
System.out.println("使用replaceAll()耗时 :" + result);
结果如下:
使用replaceAll()结果:2018-08-15VKCz, 2018-08-15VKCz,2018-08-15VKCz
使用replaceAll()耗时 :1718
三、总结
从上面测试例子对比可知,在jdk8环境下,使用replaceAll方法要比replace方法性能高,所以优先选择replace方法来满足需求比较好,不行复制下来试一试,欢迎关注java基础笔记。
更多推荐
已为社区贡献3条内容
所有评论(0)