一、背景
最近工作中碰到了将数据库表中数据导出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基础笔记。