`
hdxiong
  • 浏览: 376420 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

com.ibm.icu.text.SimpleDateFormat 的陷阱

    博客分类:
  • Java
阅读更多
在项目中经常用到SimpleDateFormat,从未出过错!
今天发现了一个奇怪的问题,一个一直正常运行的线上服务,突然在今天日志时间记录超前了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这个类吧。哎,留下此文以作纪念吧。
分享到:
评论
3 楼 suosuo230 2015-05-08  
同感,纠结了一天了,才发现,比你们晚发现2-4年
2 楼 zhukewen_java 2013-03-14  
我也被坑了下
1 楼 zhmocean 2011-06-17  
刚被这个玩意绊个跟头,只不过是自己引错了包,到底是为啥捏?IBM干了神马?

相关推荐

Global site tag (gtag.js) - Google Analytics