公交车上荫蒂添的好舒服的电影-公用玩物(np双xing总受)-公用小荡货芊芊-公与妇仑乱hd-攻把受做哭边走边肉楼梯play-古装一级淫片a免费播放口

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

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

admin
2023年7月13日 12:15 本文熱度 1737

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


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


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


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


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


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


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


1970-09-17 00:00:30.751


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


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


原因很簡單:


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


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


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


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



解決辦法


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


Ken把問題的來龍去脈講了一遍。


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


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


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


Dennis說:“這個(gè)紀(jì)元可以設(shè)定為:1970年1月1日00:00:00,那個(gè)時(shí)候Unix肯定發(fā)布了。”


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



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


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


(1) 簡化


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


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


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


(3) 兼容性


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


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


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



問題出現(xiàn)



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


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


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


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


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



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



這被稱為Y2K38問題。


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


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


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


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


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



尾聲



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


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


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


后記:Ken Thompson和Dennis Ritchie一起確定Unix紀(jì)元時(shí)間的故事是我杜撰的,大家了解下Unix紀(jì)元時(shí)間就好,不要當(dāng)真。


本文作者劉欣,著有暢銷書《碼農(nóng)翻身》,《半小時(shí)漫畫計(jì)算機(jī)》,前IBM架構(gòu)師,領(lǐng)導(dǎo)過多個(gè)企業(yè)應(yīng)用架構(gòu)設(shè)計(jì)和開發(fā)工作;洞察技術(shù)本質(zhì),擅長用故事去講解復(fù)雜技術(shù)。


該文章在 2023/7/13 12:16:37 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产精品夜夜春夜夜爽久久 | 国产大尺度福利小视频在线观看 | a级毛片毛片免费观看久潮喷 | 国产内射在线激情一区熟女我美 | 国产福利无码一区色费 | 超薄肉色丝袜一二三四区 | 国产亚洲精aa在线看 | 丰满爆乳无码一区二 | 91麻豆视频免费在线观看 | 精品国产美女福到在线不卡 | 国产蜜桃tv| 成人va在线一区二区三区四区 | 爆乳2把你榨干哦动漫在线观看 | 国产精品爆乳奶水无码视频免費 | 91嫩草国产在线观看免费 | 国产专区无码 | 精品一区二区三区免费毛片爱 | 国产欧美精品综合区 | 成人午夜福利a片在线观看 成人午夜福利电影 | 国产在线精品一品二区 | 精品久久无码高清 | 99久久一区二区三区免费 | 国产一区二区三区乱码 | av喷水高潮喷水在线观看 | 国产专区免费资源网站 | 国产精品成人有码在线观看 | 国产午夜亚洲精品国产成人 | 国产精品国产三级在线专区丘 | 国产成人aⅴ在线免费观看 国产成人aa精品一区在线播放 | 国产精品成人久久久久久久 | 国产超级aⅴ视频在线观看 国产超级a在线播放久日本 | 国产精品另类激情久久久免费 | 国产成人调教视频在线观看 | av在线亚洲av是全亚洲 | 国产精品无码专区av免费播放 | 国产精品成人av | 东京热无码中文字幕av免费 | 国产极品粉嫩福利 | 精品国产一区二区三区四区色欲 | 91国内精品久久久久怡红院 | 国产成人免费在线视频 |