一个字符串转换的问题

昨天遇到一个问题,需要将大量的时间格式字符串如”2015,10,14,18,03,01”,转化为指定格式的字符串如”2015-10-14 18:03:01” ,由于转换数据量大且频繁,所以特意研究了一下哪种方法比较高效。

  • 方法一
SimpleDateFormat timeShareSdf = new SimpleDateFormat("yyyy,MM,dd,HH,mm,ss");
SimpleDateFormat formatDateTimeSdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
for(String i : data){
    String t = formatDateTimeSdf.format(timeShareSdf.parse(i));
}

很多人写程序的人自然会想到的一种方法,其实这个在大数据量转化时,是最慢的。

  • 方法二
String regex= "(\\d{4}),(\\d{2}),(\\d{2}),(\\d{2}),(\\d{2}),(\\d{2})";
for(String i : data){
    String t = i.replaceFirst(regex, "$1-$2-$3 $4:$5:$6");
}

用正则表达式,会给人一种高大上的感觉,效率当然给方法一高不少,不过只是初级用法。

  • 方法三
String regex= "(\\d{4}),(\\d{2}),(\\d{2}),(\\d{2}),(\\d{2}),(\\d{2})";
Pattern p = Pattern.compile(regex);
for(String i : data){
    Matcher matcher = p.matcher(i);
    StringBuffer sb = new StringBuffer();
    if(matcher.find()){
       String t = sb.append(matcher.group(1))
            .append("-").append(matcher.group(3))
            .append(" ").append(matcher.group(4))
            .append(":").append(matcher.group(6))
            .toString();
    }
}

同样是正则表达式,这个写法会比前面的更高效

  • 方法四
for(String i : data){
    String[] item = i.split(",");
    StringBuffer sb = new StringBuffer();
    String t = sb.append(item[0]).append("-")
            .append(item[2]).append(" ")                  
            .append(item[3]).append(":")
            .append(item[4]).append(":")
            .append(item[5]).toString();
}

意外发现,这种情况下,这个方法会比方法三还快不少

  • 方法五
public String replaceStr(String orignStr, char[] targetArray, char[] replaceArray){
    int count = 0;
    if(orignStr == null){
        return null;
    }
    char[] cs = orignStr.toCharArray();

    for(int i = 0; i < cs.length; i++){
        if(cs[i] == targetArray[count]){
            cs[i] = replaceArray[count];
            if(count == targetArray.length - 1){
                break;
            }else{
                count++;
            }
        }
    }
    return new String(cs);
}
char[] r1 = {',',',',',',',',','};
char[] r2 = {'-','-',' ',':',':'};
for(String i : data){
    String t= replaceStr(i, r1, r2);
}

最高效的方法,从字符数组着手,比方法四快几倍,当然是针对这种情况了

总结:
其实我们编程的时候,都会有惯性思维,遇到问题往往会用习惯思路去解决,在一般情况下是没问题的,只有在特殊情况下,想得到更高效的解决办法,还是要从问题的根源去思考。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值