一、背景

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

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐