java时间戳获取字符串12小时制和24小时制

版权声明:本文为博主原创文章,未经博主允许不得转载。 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方法使用时,需要仔细查看一下,避免出现问题

猜你喜欢

转载自blog.csdn.net/wobuaizhi/article/details/85120503