广东技术师范学院后院社区's Archiver

我心飞翔 发表于 2007-2-12 20:15

将系统时间调到2038年1月19日,看看会发生什么

大家一定还记得上个世纪末给IT业界带来不少麻烦的Y2K bug吧,很不幸的是,我们很快又将面临另一个和时间有关的bug——Y2038问题。

      专家警告说,[b]Y2038 bug将于2038年1月19日(星期二)03:14:07am(GMT)正式爆发,届时人们对千年虫问题的预言可能将一一实现,比如手机网络工作不正常,卫星脱离轨道,型号较老的电脑软件软硬件无法正常工作等。[/b]

[b]什么是Y2038 bug[/b]

       [b]Time_t是C/C++ 等编程语言在内部代表/存储日期和时间的一种数据类型。Time_t实际上是一个代表秒数的整数,当它的值为0时,代表的时间是1970年1月1日12:00:00;当Time_t=60时,则表示1970年1月1日12:01:00,依此类推。

      所有32位电脑系统都用带符号32位整型来存储Time_t的值,也就是说Time_t只能用31位二进制数来表示(第一位用来表示正负号),而其最大值转换为十进制是2147483647,换算成日期和时间刚好是2038年1月19日03:14:07am(GMT),而这一秒过后,Time_t的值将变成-2147483647,代表的是1901年12月13日8:45:52pm,这样32位软硬件系统的日期时间显示就都乱套了。另外,无法接受Time_t为负值的其他功能也将返回错误。[/b]

       举个实际的例子来说,登陆上Yahoo messenger,给好友发个消息,恩没问题,现在把系统时间更改为2038年1月19日03:14:07am,此时如果再发消息Yahoo messenger就将崩溃。

[b]为何担忧?[/b]

       也许有人觉得2038年还早着,无需担心这个问题。不幸的是,上世纪60年代的程序开发人员也抱有类似的错误想法,并由此导致了Y2K问题,给全球IT业带来数十亿美元的损失。

       要知道时间对于许多电脑程序来说都非常重要,操作系统、数据库程序、电子表格软件、实时控制系统等无不涉及到时间。因此我们必须在Y2038 bug爆发前做好充足的准备。

       [b] 尽管到2038年,桌面PC和服务器基本上都将升级到64位甚至128位,但仍会有许多使用中的32位甚至更古老的系统。即使是在32位系统盛行的今天,大多数嵌入式系统仍是8位或16位的,而小型嵌入式系统的数量其实比台式机更多。[/b]

[b]如何应对?[/b]

        Y2038问题和Y2K一样难缠,其中一种解决办法就是用位数更多的数据类型来存储日期和时间。如果使用64位数据类型,Time_t最大可以表示公元292000000000年,是宇宙估计年龄的20倍,最起码看到这篇文章的各位都不会再遇到什么YXXXX问题了。

        目前对于Y2038 bug的影响有多大还存在争论,但有一点可以肯定的是:有备无患。相信我们能像克服Y2K问题那样圆满解决Y2038问题。

[color=red][b]大家也可以把自己电脑的系统时间年份改成2038看看效果,运行一下各种软件 [s:1] [/b] [/color]

暴走天使 发表于 2007-2-12 20:17

[s:1] 真是好玩

bushbush 发表于 2007-2-12 20:32

bu  ming bai

☆深蓝☆ 发表于 2007-2-13 10:18

不明白就试一下...就明了.嘿.[s:1]

¥¤¥ 发表于 2007-2-13 16:05

现在都用上64位了  这个问题不难解决

暴走天使 发表于 2007-2-17 01:23

时间过得太快.我会老的

穿风衣的猫 发表于 2007-2-19 19:16

恩。在这里可以学很多电脑知识哦。[s:12]

muc8888 发表于 2007-2-26 03:05

《面向对象程序设计》讲到类举的例子好像就是解决循环问题

有没有那么严重

即使会出现溢出,可是2038年,鬼才知道那时是个什么时代,即使现在的软件可能用到,但也是极

少的,现在都是64位处理器!新的系统是64位的!软件也都跟着改,这种担忧。。。 。。。

5476 发表于 2007-3-13 14:12

对我而言,有点远

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.