版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wobuaizhi/article/details/85120503
案例
今天线上出现一个问题,一个定时任务报错,这个定时任务每天跑四次。用了小半年也没有发现问题。这次突然报错,最初的猜想是不是修改了什么代码逻辑导致的
通过log日志定位发现
是生成了两个相同的taskId号,之前使用生成的方式是:
public static String generateSSTime() {
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddhhmmssSS");
return format.format(new Date());
}
看到这里大概知道原因了。
yyyyMMddhhmmssSS这里的h代表12小时制
yyyyMMddHHsmmssSS采用这个就可以了
也就是说,比如一个凌晨三点的任务和下午三点的任务,就会有可能出现相同的字符串
下面通过demo演示一下差别:
Calendar cl = Calendar.getInstance();
System.out.println(generateHHTime(cl.getTime()));
System.out.println(generatehhTime(cl.getTime()));
Calendar cl1 = Calendar.getInstance();
cl1.set(Calendar.HOUR, 3);
System.out.println(generateHHTime(cl1.getTime()));
System.out.println(generatehhTime(cl1.getTime()));
Calendar cl2 = Calendar.getInstance();
cl2.set(Calendar.HOUR, 15);
System.out.println(generateHHTime(cl2.getTime()));
System.out.println(generatehhTime(cl2.getTime()));
public static String generateHHTime(Date date) {
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmssSS");
return format.format(date);
}
public static String generatehhTime(Date date) {
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddhhmmssSS");
return format.format(date);
}
结果:
2018122013595115
2018122001595115
2018122015595160
2018122003595160
2018122103595161
2018122103595161
可以看出,如果使用12小时制的话,是可能出现相同时间戳字符串的。
对有些java方法使用时,需要仔细查看一下,避免出现问题