編程語言中一些令人抓狂的規(guī)則
摘要:許多年前在編程語言設(shè)計和操作系統(tǒng)上的選擇可能當(dāng)時看起來無關(guān)緊要。但是,這些遠古的決定至今仍然繼續(xù)困擾著軟件開發(fā)者。下面所介紹的就是一些在編程語言和操作系統(tǒng)里的那些讓開發(fā)者頭疼的過時的選擇。
眾所周知,軟件開發(fā)者每天都要做各種各樣的決定:如何最好的實現(xiàn)功能、如何修復(fù) bug、如何提升應(yīng)用程序的性能等等。但是他們同樣是在別人的勞動成果下面繼續(xù)做自己的決定的,比如說:他們使用的是別人開發(fā)出來的編程語言和操作系統(tǒng)以及各種開發(fā)工具。一些語言開發(fā)和系統(tǒng)設(shè)計行業(yè)里的前輩以前所作出的決定在那個時候可能是很有意義的,不過在現(xiàn)在看來可能是多此一舉。 舉例而言,在 2009 年的時候,互聯(lián)網(wǎng)創(chuàng)始人蒂姆 · 伯納斯 - 李就承認,互聯(lián)網(wǎng)網(wǎng)址中 http: 后面的兩條斜線 // 其實并無必要,他為這帶來的不便致歉。蒂姆以幽默的環(huán)保角度道歉說:真不知道這兩條斜線浪費了多少時間、打印墨水和紙張。 除此之外,對于每天都要寫代碼的軟件開發(fā)者來說,前輩們當(dāng)時做出的令后人覺得蛋疼的決定還遠不止這些。接下來就介紹一下在編程語言和操作系統(tǒng)里的那些讓開發(fā)者頭疼的過時的選擇。 1. Unix 隱藏 dot 文件("." 文件) 早期的 Unix 操作系統(tǒng)就這樣設(shè)計過:當(dāng)通過 ls 命令把目錄內(nèi)容列出來的時候,任何以 . 開始的文件或目錄會在默認情況下被隱藏起來。 從目錄列表里隱藏當(dāng)前 ( . ) 或者是隱藏根目錄 ( . . ) 的方法將所有帶 . 的文件有效地隱藏起來了。從那時起,點文件經(jīng)常性的會被忽視掉,同時也成為一種提供惡意文件的簡單方法。 " 在之前的 40 年里,因為這一個小小的走捷徑而導(dǎo)致多少 bug 的出現(xiàn)?浪費了多少 CPU 循環(huán)?出現(xiàn)了多少人為失誤?所以我們應(yīng)該記?。合麓稳绻氵€想在代碼里抄近路的話,一定要想想之前的教訓(xùn)。" ——Rob Pike 2. JavaScript 使用 + 字符串連接 大約在 20 年前,當(dāng) Netscape 首先開發(fā) JavaScript 的時候,他決定大量使用 + 操作符來連接字符串,主要是用在數(shù)字加法運算和字符串連接這兩方面上。 可是最后結(jié)合 JavaScript 的弱類型發(fā)現(xiàn),使用 + 操作符通常會導(dǎo)致數(shù)值變量的連接,而不是數(shù)值的加減。其他的編程語言同樣選擇了不同的連接操作符,或者是安排專門的程序員嚴格輸入變量,以防混淆。 " 當(dāng)我第一次學(xué)習(xí) JavaScript 的時候,真的把我害慘了,因為前后不一致的的輸入行為使得很難在最后的檢查過程中發(fā)現(xiàn) bug。" ——Chris Dutrow 3. Microsoft 選擇反斜杠作為路徑分隔符 在 1983 年的時候,微軟發(fā)布了 MS-DOS 2.0,它包括了一個目錄層次結(jié)構(gòu),就像 Unix。但是和 Unix 有所不同,Unix 使用正斜杠 ( / ) 來分割目錄路徑,微軟使用了反斜杠 ( ) ,原因是,正斜杠已經(jīng)被用于表示命令行選項,所以微軟選擇了反斜杠。 反斜杠在 Unix 和其他的例如 Perl 和 C 語言中主要是用來區(qū)分后后面緊跟著的字符,所以這給程序員帶來的痛苦就是要經(jīng)常在正斜杠和反斜杠之間來來回回的兜圈子,以免出錯。 " 回想起來,我覺得這是一個可怕的決定,但是換成是我的話,當(dāng)時可能會做出同樣的舉動。" ——Dave Lindbergh 4. Python 使用縮進表示塊 絕大多數(shù)編程語言使用明確的分隔符,例如用大括號來表示語句的分組,而 Python 卻不是這樣的,它使用前導(dǎo)空白 ( 空格和制表符 ) 來表示哪一個塊屬于哪一行代碼。 事實上,只有那些經(jīng)驗豐富的 Python 程序員比較傾向于使用這個功能,而對于那些新手或者是不常使用它的程序員來說,別提有多惱怒了,尤其是剪切代碼、粘貼代碼、改變平臺,或者是重構(gòu)代碼的時候。 " 在兩個平臺之間轉(zhuǎn)換的過程中,你會發(fā)現(xiàn)這真是編程語言里的極品功能??!" ——Joe Zitzelberger 5. Tony Hoare 發(fā)明了空引用 在 1965 的時候,英國著名計算機科學(xué)家 Tony Hoare 將空引用概念引入到 ALGOL W 語言里,以確保所有使用的引用內(nèi)容都是安全的。一直到現(xiàn)在,這一發(fā)明都存在于大部分編程語言里。 編譯器是不會抱怨空指針的,但是想要廢棄一個可能會導(dǎo)致運行時錯誤或系統(tǒng)崩潰的引用的話,那么程序員必須設(shè)法做一些防御措施或者是調(diào)試工作。 " 我認為它是一個導(dǎo)致數(shù)十億美元損失的錯誤。" ——Tony Hoare 6. JavaScript 使用分號插入 JavaScript 中分號表示語句結(jié)束,但 JavaScript 會自動的在它認為合適的地方插入分號。例如在程序結(jié)尾,或者在緊接 1 個新行的 return 語句后面。 在某些情況下,return 后面可能會有大括號和新的代碼塊,這種情況下,如果自動插入分號,就有可能導(dǎo)致語法錯誤。 " 這一功能著實讓開發(fā)者的工作出現(xiàn)了一點混亂,尤其是當(dāng)你為一個生產(chǎn)環(huán)境壓縮代碼的時候。" ——Mike Nelson 7. 如何表示日期 在如何表示日期這一問題上已經(jīng)產(chǎn)生過很多比較有效地選擇方案了,例如只使用兩個數(shù)字或者是更少的數(shù)字來表示年份,可以被四整除的年份是閏年,或者是像 Unix 系統(tǒng)那樣提供的基本時間服務(wù)是國際標(biāo)準(zhǔn)時間公元 1970 年 1 月 1 日 00:00:00 以來經(jīng)過的分秒,這種秒數(shù)是以數(shù)據(jù)類型 time_t 表示的。我們稱它們?yōu)槿諝v時間,日歷時間包括時間和日期。 只使用兩個數(shù)字或者是更少的數(shù)字來表示年份就會導(dǎo)致眾所周知的Y2K問題,計算閏年的過程中也是會出現(xiàn)很多 bug,有些系統(tǒng)照樣會出現(xiàn)Y2K38 問題。 " 在 20 世紀(jì) 60 年代的時候,內(nèi)存的價值大約為 1 美元 / 字節(jié)。所以,在 60 年代或者是在 80 年代的時候使用 2 個數(shù)字來表達年份是很合理的。可問題就在于是穩(wěn)定而精確的軟件所運行的時間完全超出了其預(yù)期的設(shè)計時間。" ——Fred Krampe 原文:InfoWorld 該文章在 2014/3/24 23:39:15 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |