不認(rèn)2月29?歇菜的可遠(yuǎn)不止自動駕駛
當(dāng)前位置:點(diǎn)晴教程→閑情逸致
→『 微信好文 』
今天,2024年2月29日,有消息稱,激光雷達(dá)大廠禾賽,遭遇了閏年bug:固件沒處理閏年,凡是用了禾賽激光雷達(dá)的車,自動駕駛功能全都歇菜了。 據(jù)“鳳凰網(wǎng)科技”,禾賽已經(jīng)回應(yīng):有2個老款L4機(jī)械式激光雷達(dá)今天出現(xiàn)了軟件bug,問題原因已經(jīng)找到,我們也跟相關(guān)客戶都做了深入溝通、并提供了相關(guān)解決方案。預(yù)計該問題會在24小時內(nèi)徹底解決。此問題不涉及AT128、不影響OEM客戶,對路上跑的所有搭載AT128的乘用車都無影響。 禾賽的合作廠商,包括理想、長城、路特斯、飛凡等。聲明中特別提及“不受影響”的AT128,則是禾賽的旗艦產(chǎn)品,已搭載在理想L9、路特斯EMEYA等車型上。 圖源:微博截圖 每4年就有一個2月29日,形形色色的閏年日bug總是準(zhǔn)時出現(xiàn)。 什么是閏年日Bug?簡單來說,就是在閏年多出來的這一天,由于對日期和時間的計算處理存在錯誤,導(dǎo)致某些系統(tǒng)或設(shè)備無法正常工作的問題。這類Bug如果不及時發(fā)現(xiàn)和修復(fù),就可能造成嚴(yán)重后果。 圖源:DALL-E 下面幾個真實(shí)案例可以幫助我們更好地理解閏年日Bug的危害:
類似的案例還有很多,比如航空公司無法正常登機(jī)、售票系統(tǒng)癱瘓、交通設(shè)施發(fā)生故障等,嚴(yán)重影響著人們的出行和生活。 其實(shí),除了四年一遇的閏年日bug,在手機(jī)和電腦上還有其他跟日期有關(guān)的奇怪bug,比如—— 世界末日到底是哪一天? 這個無厘頭的問題一直有著各種各樣的離奇答案。當(dāng)你打開手機(jī)系統(tǒng)設(shè)置(不是日歷),關(guān)閉自動設(shè)置時間,往未來的方向滑動數(shù)字時,你會發(fā)現(xiàn)時間停在了2038年。 小米、華為可以設(shè)置到2037年12月31日,iPhone也只多兩天 不僅是手機(jī),在電腦上,當(dāng)你嘗試將時間從2037年再往上調(diào)整時,會發(fā)現(xiàn)不管怎么按設(shè)置按鈕,日期都不會繼續(xù)改變。 日期調(diào)整超過2038年時,會停在2038年1月1日 2038年到底會發(fā)生什么?為什么各種設(shè)備都無法“逾越”2038年?在網(wǎng)上搜尋2038,你還能發(fā)現(xiàn)有人專門設(shè)置了倒計時網(wǎng)頁。這其中包含了一個更加精確的時間:2038年1月19日 3點(diǎn)14分7秒。而下一秒,你的電子設(shè)備將會穿越回到1901年。 著名的“2038問題”,將在此刻爆發(fā)。 到“2038年問題”發(fā)生,還剩…… 2038年,時間“摧毀”系統(tǒng) 問題發(fā)生在2038年1月19日 3點(diǎn)14分7秒的下一秒。這一天的03:14:08不會到來,迎接你的將會是1901年12月13日20:45:52。 使用腳本模擬系統(tǒng)時間,會出現(xiàn)時間的跳變(平臺 Debian GNU/Linux (內(nèi)核 2.4.22))丨William Porquet/deepsky.com 對于很多電子設(shè)備而言,這是個毀滅性的打擊。文件的創(chuàng)建與修改、應(yīng)用軟件的運(yùn)行、網(wǎng)絡(luò)系統(tǒng)的同步……時間作為一個關(guān)鍵數(shù)值,在整個電子系統(tǒng)里起著絕對重要的作用。因此有一陣子蘋果手機(jī)的語音助手Siri,還把這一天當(dāng)成了“世界末日”。為什么是這一天?Siri回答中的關(guān)鍵詞也給出了答案。 早期Siri對于世界末日問題的回答(新版本系統(tǒng)已無此回答) Unix、32位,這兩個詞讓2038年的這一天注定成為末日。Unix是一種操作系統(tǒng),這種系統(tǒng)中計時方式是以1970年1月1日 00:00:00為基準(zhǔn),按秒為單位進(jìn)行增減。比如到2022年1月1日0點(diǎn),只需要用基準(zhǔn)值加上1640966400秒。而我們現(xiàn)在使用的安卓、蘋果系統(tǒng)都屬于類Unix系統(tǒng),采用了同樣的方案。 電子系統(tǒng)使用0和1對數(shù)據(jù)進(jìn)行儲存,也就是二進(jìn)制。如果只用1位數(shù),只能表示0和1,如果2位數(shù),則可以用00、01、10、11分別表示0、1、2、3這四個數(shù)。隨著位數(shù)的增加,二進(jìn)制可以表示的數(shù)也越來越大,但總會遇到上限。如果用32個0、1儲存數(shù)字,第一位表示符號,0代表+,1代表-,則剩下31位最大可以表示2147483647。在計算機(jī)資源非常寶貴的年代,用32位來放置時間,已經(jīng)很夠用了。 1970年1月1日00:00:00 + 2147483647秒 = 2038年1月19日 3點(diǎn)14分7秒。下一秒,數(shù)據(jù)就會出現(xiàn)“裝不下”的情況,發(fā)生溢出。此時第一位符號位從0變成1,本來的加號變成了減號,時間突然穿越到過去。 從上到下分別是二進(jìn)制秒數(shù)、對應(yīng)的十進(jìn)制秒數(shù)、32位Unix系統(tǒng)時間、實(shí)際時間。超過2147483647后,符號位會變成1(負(fù)號),整個數(shù)字會突然發(fā)生翻轉(zhuǎn),回到1901年。丨Pemu/Wikicommons 這個存在于將來的問題,它會給我們帶來怎樣的影響?回溯過往,一次又一次的“千年蟲”問題已經(jīng)給了我們一些預(yù)告。 千年之外的千年蟲 2000年,千禧年。而在很多應(yīng)用程序看來,這一年會變成1900年。 同樣因為硬件資源寶貴,早期程序使用了年份的后兩位數(shù)字來表示日期,而前兩位數(shù)都默認(rèn)為19。這個不起眼的時間問題,在整個世界引發(fā)了巨大的關(guān)注。政務(wù)系統(tǒng)、銀行系統(tǒng)、航空系統(tǒng)等多個系統(tǒng)都可能受到影響而失效。全球各地對這一問題進(jìn)行了響應(yīng),試圖解決這一問題。我國多次發(fā)文強(qiáng)調(diào)這一問題的重要性。美國也推出了有關(guān)千年蟲問題的法案,以敦促各行業(yè)共享信息解決此類問題。 全球各地對“千年蟲”采取行動丨人民日報網(wǎng)絡(luò)版 多虧人們對“千年蟲”的高度重視,使得這一問題在集中爆發(fā)前得以解決。但在此之后,類似“千年蟲”的事件卻依然層出不窮。 2010年的第一周,德國約3千萬張銀行卡同時“失效”。持卡人不僅無法直接刷卡消費(fèi),連在自動取款機(jī)上取錢都成問題。這不僅影響了本國居民的生活,也使得在外度假的德國人滯留在當(dāng)?shù)亍?/p> 由于不同編碼方式存在差異,2010在德國的銀行系統(tǒng)中被錯誤地識別成2016。銀行卡也因此“被過期”了。同樣的情況出現(xiàn)在使用Windows Mobile系統(tǒng)的手機(jī)上:你在2010年第一天收到的新年短信,會被系統(tǒng)顯示成2016年。 德國加速修復(fù)了銀行系統(tǒng),所幸沒有造成更大的損失。但放眼太空,事情就沒那么簡單了。2013年9月,航天器Deep Impact突然失聯(lián),迫使美國航空航天局宣布相關(guān)探測任務(wù)正式結(jié)束。Deep Impact的首席任務(wù)科學(xué)家 Mike A'Hearn認(rèn)為,這是一個“千年蟲問題”。航天器的部分軟件無法正確識別2013年8月11日之后的日期,導(dǎo)致計算機(jī)不斷重啟。最終,科學(xué)家們失去了航天器的信號。 Deep Impact與坦普爾1號彗星相遇模擬圖丨NASA 就在2022年初,“2022年蟲”讓微軟的程序員體會了新年大加班。1月1日,微軟的郵件服務(wù)系統(tǒng)Exchange突然中斷,使用該服務(wù)的用戶都無法發(fā)送電子郵件。微軟隨后給出了聲明,稱該問題與日期檢查失敗以及新年的變化有關(guān)。簡單點(diǎn)說,和2038問題一樣,時間“溢出”了。好在微軟團(tuán)隊加班加點(diǎn),在當(dāng)天解決了該問題。 在未來,“類千年蟲”問題一定還會出現(xiàn)。對于可以預(yù)料的問題,人們已經(jīng)開始嘗試提供解決方法。比如使用新的格式存儲時間信息。與此同時,系統(tǒng)團(tuán)隊提供的新內(nèi)核也在解決32位平臺上的“歷史問題”。你也不用太擔(dān)心,畢竟到那時,你應(yīng)該已經(jīng)換了好幾波手機(jī)了。 不過,再遇到類似的突發(fā)Bug也很正常。因為世界上總在發(fā)生情理之中、意料之外的事情。 轉(zhuǎn)自網(wǎng)易號https://www.163.com/dy/article/IS54S21F05118OGM.html 該文章在 2024/3/5 15:44:11 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |