0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

50多年前,大神在操作系統(tǒng)中埋的雷快要爆了

dyquk4xk2p3d ? 來(lái)源:良許Linux ? 2023-08-21 16:31 ? 次閱讀

1969年,貝爾實(shí)驗(yàn)室的大神Ken Thompson的老婆休假,帶著兒子回娘家,時(shí)間長(zhǎng)達(dá)三周。

趁這段時(shí)間,他決定開(kāi)發(fā)一個(gè)操作系統(tǒng):Uni

正在如火如荼地敲代碼的時(shí)候,Ken突然卡殼了,這是一件非同尋常的事情,之前的開(kāi)發(fā)都是一帆風(fēng)順,行云流水的。

因?yàn)樗庾R(shí)到有個(gè)非常重大的問(wèn)題,必須馬上解決。

這個(gè)問(wèn)題就是:如何在Unix中表示日期和時(shí)間?

這個(gè)問(wèn)題非常重要,因?yàn)槿掌诤蜁r(shí)間管理對(duì)于任何操作系統(tǒng)來(lái)說(shuō)都是關(guān)鍵功能,包括文件時(shí)間戳、程序調(diào)度、日志記錄等。

最容易想到,也是最簡(jiǎn)單的辦法就是用一個(gè)字符串來(lái)表示,例如:

1970-09-17 0030.751

有年月日,時(shí)分秒,還有細(xì)粒度的微妙,并且可讀性非常強(qiáng)。

但是這種方式明顯不符合Unix的設(shè)計(jì)原則:簡(jiǎn)潔,一致性,易于使用。

原因很簡(jiǎn)單:

(1) 存儲(chǔ)效率低下

字符串需要占用大量的空間,處理起來(lái)也更復(fù)雜

(2) 計(jì)算復(fù)雜性讀比較高

比如要計(jì)算兩個(gè)時(shí)間的差值,需要先解析字符串,然后進(jìn)行更復(fù)雜的日期和時(shí)間計(jì)算。

解決辦法

正當(dāng)Ken一籌莫展之際,Dennis Ritchie端著咖啡走了過(guò)來(lái):“兄臺(tái),遇到什么事情了?”

Ken把問(wèn)題的來(lái)龍去脈講了一遍。

Dennis沉吟道:“嗯,這確實(shí)是一個(gè)問(wèn)題,得有一個(gè)簡(jiǎn)潔易用的,符合Unix設(shè)計(jì)原則的方案....”

突然,Dennis一拍大腿:“用一個(gè)整數(shù)來(lái)表示日期和時(shí)間怎么樣?”

聰明異常的Ken立刻秒懂,眼睛發(fā)光:“對(duì),先確定一個(gè)開(kāi)始時(shí)間(紀(jì)元),然后這個(gè)整數(shù)表示從紀(jì)元開(kāi)始到當(dāng)前時(shí)間流逝的秒數(shù)!”

Dennis說(shuō):“這個(gè)紀(jì)元可以設(shè)定為:1970年1月1日0000,那個(gè)時(shí)候Unix肯定發(fā)布了?!?/p>

如果這個(gè)整數(shù)是:1631280731,那就表示2021-09-10 1331 UTC

4fd379f4-3fb2-11ee-ac96-dac502259ad0.png

Ken Thompson決定把這種方式成為Unix Epoch Time(Unix 紀(jì)元時(shí)間)。

用一個(gè)整數(shù)來(lái)表示時(shí)間戳,有幾個(gè)主要的優(yōu)勢(shì):

(1) 簡(jiǎn)化

通過(guò)將日期和時(shí)間表示為一個(gè)單一的整數(shù),可以大大簡(jiǎn)化日期和時(shí)間的計(jì)算。例如,計(jì)算兩個(gè)日期之間的差異就只需要對(duì)兩個(gè)整數(shù)進(jìn)行減法運(yùn)算。

(2) 便于存儲(chǔ)和處理

整數(shù)易于存儲(chǔ)(占用的空間較少)且便于在各種編程語(yǔ)言中處理。

(3) 兼容性

Unix時(shí)間戳可以在不同的操作系統(tǒng)和平臺(tái)之間輕松地進(jìn)行交換和比較。

(4) 全球統(tǒng)一

Unix時(shí)間戳是從同一時(shí)刻(1970年1月1日0000 UTC)開(kāi)始的,所以它提供了一種在全球范圍內(nèi)統(tǒng)一的時(shí)間表示方式。

問(wèn)題出現(xiàn)

當(dāng)然,Unix時(shí)間戳也有其限制。例如,它不能很好地處理閏秒,而且直接查看Unix時(shí)間戳并不能很好地理解當(dāng)前的日期和時(shí)間。

在上世紀(jì)六七十年代,電腦主要還是16位的,Ken Thompson把Unix時(shí)間戳確定為32位整數(shù),他覺(jué)得已經(jīng)夠大了,再說(shuō)了誰(shuí)會(huì)知道Unix操作系統(tǒng)能用多久呢?

讓人想不到的是Unix一直存活了下來(lái),它的很多概念對(duì)整個(gè)計(jì)算機(jī)科學(xué)和軟件開(kāi)發(fā)領(lǐng)域產(chǎn)生了深遠(yuǎn)的影響,包括時(shí)間和日期的處理方式。類Unix的開(kāi)源操作系統(tǒng)Linux繼承了Unix的衣缽,甚至統(tǒng)治了服務(wù)器端的OS市場(chǎng)。

開(kāi)發(fā)Linux的時(shí)候,也是采用了32位的整數(shù)來(lái)記錄時(shí)間戳。

現(xiàn)在一個(gè)大問(wèn)題來(lái)了,32位的有符號(hào)整數(shù)最大值是2147483647 ,只能讓我們用到2038年1月19號(hào) 0307 UTC

50117722-3fb2-11ee-ac96-dac502259ad0.png

下面這個(gè)動(dòng)圖展示了整數(shù)溢出以后的效果:

503c09ce-3fb2-11ee-ac96-dac502259ad0.gif

這被稱為Y2K38問(wèn)題。

解決方案也非常簡(jiǎn)單,就像IPV6一樣,用128位IP,可以給地球上每一粒沙子都賦予一個(gè)IP地址,并且還有大量剩余。

Unix Epoch time 可以把32位的整數(shù)變成64位。

使用64位整數(shù),可以表示到接近290億年后的時(shí)間,不知道那個(gè)時(shí)候地球還是否存在?

大概是從Linux 5.6版本開(kāi)始,Linux內(nèi)核開(kāi)始全面支持64位時(shí)間戳的系統(tǒng)調(diào)用,但是升級(jí)了內(nèi)核以后,并不意味著完事大吉,應(yīng)用程序和庫(kù)在編寫的時(shí)候如果使用了time_t類型(早期是32位的),現(xiàn)在需要改成64位整數(shù),然后重新編譯,要不然依然會(huì)產(chǎn)生溢出問(wèn)題。

嵌入式系統(tǒng)最有可能受到Y(jié)2K38問(wèn)題的影響,一般的服務(wù)器軟件通常會(huì)定期進(jìn)行升級(jí),打補(bǔ)丁,但是嵌入式軟件一旦隨著硬件發(fā)布出去,就很少更改,很可能會(huì)運(yùn)行到2038年。

尾聲

在Unix Epoch Time確定下來(lái)30年后,一個(gè)準(zhǔn)備轉(zhuǎn)行Java程序員的年輕人打開(kāi)了Java 的Date類。

Date內(nèi)部實(shí)際上存儲(chǔ)的就是一個(gè)長(zhǎng)整型的數(shù)(long),它表示的是自1970年1月1日 0000 (即Unix Epoch時(shí)間)以來(lái)的毫秒數(shù)。

他覺(jué)得非常奇怪:為什么是1970年1月1日 0000呢?是誰(shuí)確定了這么一個(gè)古怪的日期呢?

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 存儲(chǔ)
    +關(guān)注

    關(guān)注

    13

    文章

    4507

    瀏覽量

    87091
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    7098

    瀏覽量

    124995
  • UNIX
    +關(guān)注

    關(guān)注

    0

    文章

    296

    瀏覽量

    42111

原文標(biāo)題:50 多年前,大神在操作系統(tǒng)中埋的雷,快要爆了…

文章出處:【微信號(hào):良許Linux,微信公眾號(hào):良許Linux】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    鴻道Intewell操作系統(tǒng):人形機(jī)器人底層操作系統(tǒng)

    操作系統(tǒng)的實(shí)時(shí)性賦能東土科技的鴻道(Intewell)工業(yè)操作系統(tǒng)作為國(guó)內(nèi)唯一通過(guò)汽車、工業(yè)控制、醫(yī)療、軌道交通四項(xiàng)功能安全認(rèn)證的系統(tǒng),為標(biāo)準(zhǔn)體系的技術(shù)層架構(gòu)提供
    的頭像 發(fā)表于 05-16 14:44 ?152次閱讀

    使用Chaquo插件Android操作系統(tǒng)安裝OpenVINO工具套件遇到報(bào)錯(cuò),怎么解決?

    使用 chaquo 插件 Android* 操作系統(tǒng)安裝 OpenVINO? 時(shí)遇到以下錯(cuò)誤: ERROR: Could not find a version that satisfies
    發(fā)表于 03-05 06:06

    實(shí)時(shí)操作系統(tǒng)RTOS選型指南及實(shí)例分析

    操作系統(tǒng)實(shí)現(xiàn)控制、計(jì)算和云服務(wù)的融合統(tǒng)一,為控制層多種類型的設(shè)備提供統(tǒng)一的互聯(lián)互通服務(wù)能力。鴻道Intewell操作系統(tǒng)經(jīng)過(guò)多年高實(shí)時(shí)性和可控性驗(yàn)證并穩(wěn)定運(yùn)行,是目前國(guó)內(nèi)唯一通過(guò)汽車
    的頭像 發(fā)表于 02-27 15:21 ?473次閱讀

    鴻道Intewell操作系統(tǒng)的Linux實(shí)時(shí)拓展方案

    鴻道Intewell操作系統(tǒng)是科東軟件自主研發(fā)的新型工業(yè)實(shí)時(shí)操作系統(tǒng),歷經(jīng)30多年研發(fā)積累,采用業(yè)界領(lǐng)先的微內(nèi)核架構(gòu),具備高實(shí)時(shí)、高安全及強(qiáng)擴(kuò)展的特性,是目前國(guó)內(nèi)唯一通過(guò)汽車、工業(yè)控制、醫(yī)療儀器、軌道交通四項(xiàng)功能安全認(rèn)證的
    的頭像 發(fā)表于 02-27 10:08 ?339次閱讀
    鴻道Intewell<b class='flag-5'>操作系統(tǒng)</b>的Linux實(shí)時(shí)拓展方案

    【「鴻蒙操作系統(tǒng)設(shè)計(jì)原理與架構(gòu)」閱讀體驗(yàn)】01-初始華為鴻蒙

    的誕生創(chuàng)造條件,同時(shí)也提出了新的要求。 操作系統(tǒng)是連接計(jì)算機(jī)硬件和軟件的橋梁,計(jì)算機(jī)系統(tǒng)處于非常重要的位置。
    發(fā)表于 01-25 11:05

    國(guó)產(chǎn)銀河麒麟操作系統(tǒng)V10和星光麒麟V1.0操作系統(tǒng)如何選擇?

    國(guó)產(chǎn)銀河麒麟操作系統(tǒng)和星光麒麟操作系統(tǒng)都是由中國(guó)電子旗下科技企業(yè)麒麟軟件有限公司(簡(jiǎn)稱“麒麟軟件”)開(kāi)發(fā)的國(guó)產(chǎn)自主可控的操作系統(tǒng)。麒麟軟件介紹:麒麟軟件以安全可信操作系統(tǒng)技術(shù)為核心,面
    的頭像 發(fā)表于 01-24 09:14 ?1876次閱讀
    國(guó)產(chǎn)銀河麒麟<b class='flag-5'>操作系統(tǒng)</b>V10和星光麒麟V1.0<b class='flag-5'>操作系統(tǒng)</b>如何選擇?

    deepin操作系統(tǒng)介紹

    希望從自己的能力和對(duì)桌面操作系統(tǒng)的理解,能給 Linux 的用戶與開(kāi)發(fā)者更多的選擇。我們也相信 deepin 能夠得到更多用戶的認(rèn)可與喜愛(ài),成為開(kāi)源世界的最佳選擇。? 一、 deepin 操作系統(tǒng) 先說(shuō) Linux 操作系統(tǒng),它
    的頭像 發(fā)表于 12-23 09:08 ?2090次閱讀
    deepin<b class='flag-5'>操作系統(tǒng)</b>介紹

    2024國(guó)操作系統(tǒng)大會(huì)盛大啟幕

    2024 中國(guó)操作系統(tǒng)大會(huì)在北京中國(guó)大飯店盛大啟幕。作為操作系統(tǒng)行業(yè)高規(guī)格的年度盛會(huì)和信息技術(shù)應(yīng)用創(chuàng)新產(chǎn)業(yè)的風(fēng)向標(biāo),大會(huì)已邁入第五屆。本屆大會(huì)以“創(chuàng)變·求真”為主題,旨在探討以生成式 AI 為代表的虛擬技術(shù)為操作系統(tǒng)和基礎(chǔ)軟件領(lǐng)
    的頭像 發(fā)表于 12-11 14:36 ?503次閱讀

    中科創(chuàng)達(dá)入選車載操作系統(tǒng)TOP10企業(yè)

    TOP10分析報(bào)告》,中科創(chuàng)達(dá)憑借多年操作系統(tǒng)領(lǐng)域的深厚技術(shù)積累以及智能汽車整車操作系統(tǒng)方面的卓越創(chuàng)新成功入選“車載操作系統(tǒng)TOP10企
    的頭像 發(fā)表于 11-14 11:47 ?961次閱讀

    linux操作系統(tǒng)安裝步驟 linux操作系統(tǒng)的特點(diǎn)及組成

    Linux操作系統(tǒng)安裝步驟 Linux操作系統(tǒng)是一種開(kāi)源的操作系統(tǒng),它以其穩(wěn)定性、安全性和靈活性而聞名。以下是安裝Linux操作系統(tǒng)的一般步驟,以Ubuntu為例: 1. 準(zhǔn)備工作
    的頭像 發(fā)表于 10-21 11:24 ?1128次閱讀

    新手學(xué)操作系統(tǒng) 第二周

    新手學(xué)操作系統(tǒng)1.shel程序中發(fā)命令 編輯 人在shell中發(fā)命令2.操作系統(tǒng)的基本命令3.獲取幫助信息的兩個(gè)方法
    的頭像 發(fā)表于 10-08 11:32 ?401次閱讀
    新手學(xué)<b class='flag-5'>操作系統(tǒng)</b> 第二周

    簡(jiǎn)單認(rèn)識(shí)RTOS實(shí)時(shí)操作系統(tǒng)

    RTOS(Real Time Operating System,實(shí)時(shí)操作系統(tǒng))是一種專門設(shè)計(jì)用于嚴(yán)格時(shí)間限制內(nèi)處理任務(wù)的操作系統(tǒng)。它以其高實(shí)時(shí)性、多任務(wù)處理能力和資源管理能力工業(yè)自
    的頭像 發(fā)表于 08-20 11:20 ?4877次閱讀

    Windows操作系統(tǒng)是什么?它有哪些特點(diǎn)?

    Windows操作系統(tǒng)是由美國(guó)微軟公司(Microsoft Corporation)開(kāi)發(fā)和推出的一種計(jì)算機(jī)操作系統(tǒng)。自1985年Windows 1.0版本發(fā)布以來(lái),Windows系統(tǒng)經(jīng)歷
    的頭像 發(fā)表于 08-07 16:30 ?5846次閱讀

    Windows操作系統(tǒng)的常用命令

    Windows操作系統(tǒng)提供許多實(shí)用的命令行工具,通過(guò)命令行界面(Command Prompt)或Windows PowerShell,用戶可以執(zhí)行各種任務(wù),如文件管理、系統(tǒng)維護(hù)、網(wǎng)絡(luò)配置等。掌握
    的頭像 發(fā)表于 08-07 15:40 ?1063次閱讀
    Windows<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>中</b>的常用命令

    嵌入式實(shí)時(shí)操作系統(tǒng):Intewell操作系統(tǒng)與VxWorks操作系統(tǒng)有啥區(qū)別

    Intewell操作系統(tǒng)和VxWorks操作系統(tǒng)都是工業(yè)領(lǐng)域常用的操作系統(tǒng),它們各有特點(diǎn)和優(yōu)勢(shì)。以下是它們之間的一些主要區(qū)別:
    的頭像 發(fā)表于 07-08 14:16 ?731次閱讀
    嵌入式實(shí)時(shí)<b class='flag-5'>操作系統(tǒng)</b>:Intewell<b class='flag-5'>操作系統(tǒng)</b>與VxWorks<b class='flag-5'>操作系統(tǒng)</b>有啥區(qū)別

    電子發(fā)燒友

    中國(guó)電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品