在项目中经常用到SimpleDateFormat,从未出过错!
今天发现了一个奇怪的问题,一个一直正常运行的线上服务,突然在今天日志时间记录超前了1小时,奇怪啊!找到该项目源码,测试了一下,的确时间超前了一个小时。明明现在是10:15分,格式化出来却是11:15分。同样的测试代码【main方法】拷到别的机器运行正常。在本机直接打印new Date()时间正常。说明是格式化时间(SimpleDateFormat)出错了,可是之前一直都没错过啊,SimpleDateFormat绝对不会出现这种错误的。无奈啊,现在确实是出错了,那就看看SimpleDateFormat吧!回到头部一看傻眼了,头部引入的是icu4j-2.6.1.jar包中的:
带着将信将疑我们换成了“import java.text.SimpleDateFormat;”,果然,结果正确了。也不知道当初是否受到“ibm”字眼的影响,错误的选择了这个。稍后有时间研究一下ibm这个类吧。哎,留下此文以作纪念吧。
今天发现了一个奇怪的问题,一个一直正常运行的线上服务,突然在今天日志时间记录超前了1小时,奇怪啊!找到该项目源码,测试了一下,的确时间超前了一个小时。明明现在是10:15分,格式化出来却是11:15分。同样的测试代码【main方法】拷到别的机器运行正常。在本机直接打印new Date()时间正常。说明是格式化时间(SimpleDateFormat)出错了,可是之前一直都没错过啊,SimpleDateFormat绝对不会出现这种错误的。无奈啊,现在确实是出错了,那就看看SimpleDateFormat吧!回到头部一看傻眼了,头部引入的是icu4j-2.6.1.jar包中的:
import com.ibm.icu.text.SimpleDateFormat;
貌似不是我们经常用的:
import java.text.SimpleDateFormat;
(rt.jar包)难道是这里错了。
带着将信将疑我们换成了“import java.text.SimpleDateFormat;”,果然,结果正确了。也不知道当初是否受到“ibm”字眼的影响,错误的选择了这个。稍后有时间研究一下ibm这个类吧。哎,留下此文以作纪念吧。