似乎发现了 jdk1.8 版本的一个date类的bug?

发布于 2022-01-02 20:35:57 字数 282 浏览 823 评论 23

如上图所示,从度娘上了解到结尾的+0900和+0800表示时区的意思,但是 1940和1941年的时区与其他年份不同。这就导致了,spring在格式化返回时间是使用gmt+8类型 这两个年份始终不行 需要使用 gmt+9  不是和很懂 有没有大佬指教一下

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(23

梦中楼上月下 2022-01-07 22:27:40

谢谢你的回答 但我质疑的不是格式化时间的问题, 请看一下问题补充

心欲静而疯不止 2022-01-07 22:27:39

回复
就是因为夏令时的原因,可能会导致出现CST和CDT两种时区的问题

野心澎湃 2022-01-07 22:27:38

貌似要这样
 SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            TimeZone defaultTimeZone = TimeZone.getDefault();
            TimeZone tz = TimeZone.getTimeZone("");
            tz.setID(defaultTimeZone.getID());
            tz.setRawOffset(defaultTimeZone.getRawOffset());
            format.setTimeZone(tz);

乞讨 2022-01-07 22:27:36

我已经知道答案了,可以看一下原贴我自己的回复,或者维基百科 查询 中国时区 不是代码层面的问题

累赘 2022-01-07 22:27:36

谢谢你的测试和回答,有结论的话,请跟我分享一下

岁月打碎记忆 2022-01-07 22:27:34

果然有问题,java数据转json时,实际是转成时间戳。前端js显示时,根据时间戳转化成日期,下面测试相同日期两种语言转化时间戳:
测试时间:"1939-07-30 15:02:20","1940-07-30 15:02:20","1941-07-30 15:02:20","1942-07-30 15:02:20"
java中转时间戳后:[-960137860000,-928519060000,-896983060000,-865443460000]
js中转时间戳后:[-960137860000,-928519060000,-896983060000,-865447060000]
测试结果表明"1942-07-30 15:02:20" java转换成时间戳为-865443460000,js根据此时间戳转化成日期为"1942-07-30 16:02:20",多了一小时
结论:果然有问题,但是不知道哪个是对的

巡山小妖精 2022-01-07 22:27:33

只设置TimeZone应该没用,需要设置RawOffset

好听的两个字的网名 2022-01-07 22:27:32

你再比对一下你的代码和我的代码,其实就是你的代码不是

SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss", Locale.CHINA);
format.setTimeZone(TimeZone.getTimeZone("Asia/Shanghai")); 

这样设置的。你光设置了jackson的时区,肯定不对。

英雄似剑 2022-01-07 22:27:32

这个并非本地格式化的问题 我也没有说过格式化时间有问题 我质疑的是为什么 格式化后的相同日期 不同年份显示的 时区是不同的,而且我测试了多个年份 只有 40和41年有问题,请看清问题 谢谢你的回答

草莓味的萝莉 2022-01-07 22:27:31

请问是否是按我上诉的配置进行了小的测试,可否说一下 springboot的配置 我多比一下自己的是否有问题

风透绣罗衣 2022-01-07 22:27:28

在1992年之前中国也采用夏令时的,所以会出现一天只有23小时或者25小时,因此java中的一天并不完全是24小时的。

永不分离 2022-01-07 22:27:28

但我只在41年和42年遇到这个问题……

想挽留 2022-01-07 22:27:28

正常啊

无法言说的痛 2022-01-07 22:27:27

尝试了不行,本身时间是没问题的 显示的也是对的 但是 40和41年创建出来的date时区不同

离去的眼神 2022-01-07 22:26:40

夏时令了解一下,使用"Asia/Shanghai"时区

凌乱心跳 2022-01-07 22:26:27

这个也会遇到我的问题吧 可否麻烦你 用一个小demo验证一下

孤独患者 2022-01-07 22:25:03

jdk 12.0.3.

柳絮泡泡 2022-01-07 22:22:48

如果各位觉得我验证错了 可以创建一个springboot的小demo测试一下,如果没问题,麻烦告知一下jdk的版本

高跟鞋的旋律 2022-01-07 22:21:34

可能很多然看到的第一反应就是觉得我是个彩笔,肯定哪里弄错了,那我也不反驳,贴一个测试的结果

上图已经可以看到基础的时间都是相同的,但是返回到前端的时间不同。

冷弦 2022-01-07 22:19:56

非常非常感谢你的回答,请问是否有相关的博客或者资料可以共享一下,谢谢

梅窗月明清似水 2022-01-07 21:57:36

回复
是的,看到你发的维基百科里的介绍了,原因是1940是日伪日期使用的是东京东9区的时区。其实个人觉得最科学的还是用30度经线来划分时区,像我国的新疆和北京都使用东八区,这样也就造成北京时间7:30,新疆还是5:30还没天亮呢。特别是这种抗日战争时期时区变化的事情,本来是程序问题变成了历史和地理问题搞复杂了。

千笙结 2022-01-07 11:01:40

回复
@前端大师傅 : 大佬 我这里说错了 其实不是这两年使用的东京时间 而是 这年推行了一个 叫夏令时的东西,人为调快一小时

瑾兮 2022-01-02 23:53:33

这个问题很简单,除了我楼上的是强制使用了asia/shanghai即东8区之外,而楼主使用的是gmt格尼威治天文台的gmt时间,如果是gmt时间系统会根据当时的所在时区与0点时间加或减时间,英国格尼威治天文台所在的经线为基准,将全球经线划分了24个时区,但中国是一个很特殊的情况,即30度一个时区在中国并不适用,也就是出现东9区的情况在1940年并不是bug。而是当时的时区是按正常的每30度一个时区来划分的,而后来新中国成立以后整个中国是东8区。虽然中国跨了好几个时区,仍是东8区。也就是在中国的任何一个地区都是+8。而不会出现+9,+8,+6,像我国的新疆地区应该是+6,但还是加8。

上面是原理,再说原因,jdk是不会有这种bug的,出现这个情况有两个原理:原因1就是当时的1940年在时区数据库里的时区对应关系找不到,所以采用30度加法来根据你的所在地的经度计算出来的东9,所以是+9。

 

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文