unix時間戳 爲什麼計算機時間要從1970年1月1日開始算起?

今天一時興起想起了在SQL Server中使用DateTime.MinValue插入時間時報錯的問題,原因就在於數據庫的最小時間和.Net裏的最小時間不一致導致的,網上查閱了些資料,找到如下結果
Net Framewrok 中,

DateTime.MinValue => 0001/01/01 00:00:00

SqlDateTime.MinValue.Value => 1753/01/01 00:00:00

SQL Server 2005 中,

DateTime 最小值 => 1753/01/01 00:00:00

SmallDateTime 最小值 => 1900/01/01 00:00:00

Net Framewrok 中,

DateTime.MaxValue => 9999/12/31 23:59:59.999

SqlDateTime.MaxValue.Value => 9999/12/31 23:59:59.997

SQL Server 2005 中,

DateTime 最大值 => 9999/12/31 23:59:59.997

SmallDateTime 最大值 =>2079.6.6

所以需要在數據庫插入最小時間時不能使用DateTime.MinValue,需要使用

SqlDateTime.MinValue.Value。

 

好了到現在SQL Server數據庫時間問題解決了,突然又想起了系統中有個啥1970年1月1日的時間。那這個時間又是啥來來歷呢,懷着好奇寶寶的心理我有在網上查閱了一番得到如下解釋:

1.可以簡單的這樣認爲:UNIX系統認爲1970年1月1日0點是時間紀元,所以我們常說的UNIX時間戳是以1970年1月1日0點爲計時起點時間的。這個解釋是懶人最愛^_^

 

2.這個比較科學


最初計算機操作系統是32位,而時間也是用32位表示。32位能表示的最大值是2147483647。另外1年365天的總秒數是31536000,2147483647/31536000 = 68.1,也就是說32位能表示的最長時間是68年,而實際上到2038年01月19日03時14分07秒,便會到達最大時間,過了這個時間點,所有32位操作系統時間便會變爲10000000 00000000 00000000 00000000,也就是1901年12月13日20時45分52秒,這樣便會出現時間迴歸的現象,很多軟件便會運行異常了。

到這裏,我想問題的答案已經出來了:因爲用32位來表示時間的最大間隔是68年,而最早出現的UNIX操作系統考慮到計算機產生的年代和應用的時限綜合取了1970年1月1日作爲UNIX TIME的紀元時間(開始時間),至於時間迴歸的現象相信隨着64爲操作系統的產生逐漸得到解決,因爲用64位操作系統可以表示到292,277,026,596年12月4日15時30分08秒,相信我們的N代子孫,哪怕地球毀滅那天都不用愁不夠用了,因爲這個時間已經是千億年以後了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章