Java1986-1992的坑

最近项目遇到一个稀奇的事情,有一个用户的出生日期保存之后回显就会比保存的值少一天,我们最开始以为是前端解析的问题,后面意识到可能是JSON解析器的问题,先后尝试了Gson、JackSon、fastJson,Gson默认对时间类型加了TimeZone所以没有出现上述问题,更加使我认为是JSON的锅,开始狂看fastJson的issue,搞了好久才发现是DST的问题,可怜了我的Json解析器

前情概要:

关于DST

夏时制,夏时令(Daylight Saving Time:DST),又称“日光节约时制”和“夏令时间”,是一种为节约能源而人为规定地方时间的制度,在这一制度实行期间所采用的统一时间称为“夏令时间”。一般在天亮早的夏季人为将时间调快一小时,可以使人早起早睡,减少照明量,以充分利用光照资源,从而节约照明用电。各个采纳夏时制的国家具体规定不同。目前全世界有近110个国家每年要实行夏令时。

DST在中国

1986年4月,中国中央有关部门发出“在全国范围内实行夏时制的通知”,具体作法是:每年从四月中旬第一个星期日的凌晨2时整(北京时间),将时钟拨快一小时,即将表针由2时拨至3时,夏令时开始;到九月中旬第一个星期日的凌晨2时整(北京夏令时),再将时钟拨回一小时,即将表针由2时拨至1时,夏令时结束。从1986年到1991年的六个年度,除1986年因是实行夏时制的第一年,从5月4日开始到9月14日结束外,其它年份均按规定的时段施行。在夏令时开始和结束前几天,新闻媒体均刊登有关部门的通告。1992年起,夏令时暂停实行。

1986年至1991年,每年四月的第2个星期日早上2点,到九月的第2个星期日早上2点之间。

1986年5月4日至9月14日(1986年因是实行夏令时的第一年,从5月4日开始到9月14日结束)

  • 1987年4月12日至9月13日;
  • 1988年4月10日至9月11日;
  • 1989年4月16日至9月17日;
  • 1990年4月15日至9月16日;
  • 1991年4月14日至9月15日。

以上是为啥用户的出生日期保存之后回显就会比保存的值少一天的原因,就是因为这个DST导致的,恰恰这个用户的出生日期在1986-1992这个区间,才发现了这个问题,想到在对日期Format的时候加一个TimeZone,统一一个UTC的时区

jdk1.8以前的处理

 SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
 simpleDateFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
 simpleDateFormat.format(date);

jdk1.8以后的处理

DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
Date.from(LocalDateTime.parse(startTimeString,formatter)
    .atZone(ZoneId.systemDefault()).toInstant());
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 我姓付,常有人说,这姓不好,以后做了正职,按常规叫法,听起来依然是副职。每每被人介绍,多数人都还要解释一番。我却满...
    飞常心阅读 631评论 1 3
  • 这是我的第一篇文章,好激动,如果有写的不好的地方请大家多多包涵,有不对的地方也请指出,谢谢~正常情况下UIText...
    留几分念想阅读 2,557评论 0 0
  • 经紧急磋商,玉扳手科技宣布:即日起停止玉扳手旗下“边走边学”项目与韩国乐天集团的合作意向。 2月28日,韩国国防部...
    玉扳手阅读 186评论 0 0
  • 在最近做的项目中,遇到了 Fragment 重叠的问题。在用Fragment做Tab页面,发现有时候进入应用会同时...
    Liz_Miller阅读 6,981评论 4 13