編程語言中一些令人抓狂的規則

jopen 10年前發布 | 5K 次閱讀 編程語言

        英文原文:7 long-ago decisions that still haunt developers today 

        許多年前在編程語言設計和操作系統設計上的選擇可能當時看起來無關緊要。但是,這些遠古的決定至今仍然繼續困擾著軟件開發者。

        程序員使用的是別人開發出來的編程語言和操作系統以及各種開發工具。一些語言開發和系統設計行業里的前輩以前所作出的決定在那個時候可能是很有意義的,不過在現在看來可能是多此一舉。

        舉例而言,在 2009 年的時候,互聯網創始人蒂姆·伯納斯-李就承認,互聯網網址中 http:后面的兩條斜線//其實并無必要,他為這帶來的不便致歉。蒂姆以幽默的環保角度道歉說:真不知道這兩條斜線浪費了多少時間、打印墨水和紙張。

        除此之外,對于每天都要寫代碼的軟件開發者來說,前輩們當時做出的令后人覺得蛋疼的決定還遠不止這些。接下來就介紹一下在編程語言和操作系統里的那些讓開發者頭疼的過時的選擇。

        1. Unix 隱藏點文件

        早期的 Unix 操作系統就這樣設計過:當通過ls命令把目錄內容列出來的時候,任何以 . 開始的文件或目錄會在默認情況下被隱藏起來。

        從那時起,點文件經常性的會被忽視掉,同時也成為惡意文件藏身的一種簡單方法。

編程語言中一些令人抓狂的規則

“在之前的 40 年里,因為這一個小小的走捷徑而導致多少 bug 的出現?浪費了多少 CPU 循環?出現了多少人為失誤?所以我們應該記住:下次如果你還想在代碼里抄近路的話,一定要想想之前的教訓。”——Rob Pike

        2. JavaScript 使用“+”來連接字符串

        大約在 20 年前,當 Netscape 首先開發 JavaScript 的時候,他決定大量使用+操作符來連接字符串,主要是用在數字加法運算和字符串連接這兩方面上。

編程語言中一些令人抓狂的規則

        可是最后結合 JavaScript 的弱類型發現,使用+操作符通常會導致數值變量的連接,而不是數值的加減。其他的編程語言同樣選擇了不同的連接操作符,或者是安排專門的程序員嚴格輸入變量,以防混淆。

“當我第一次學習 JavaScript 的時候,真的把我害慘了,因為前后不一致的的輸入行為使得很難在最后的檢查過程中發現 bug。”——Chris Dutrow

        3. 微軟選擇反斜杠作為路徑分隔符

        在 1983 年的時候,微軟發布了 MS-DOS 2.0,它包括了一個目錄層次結構,就像 Unix。但是和 Unix 有所不同,Unix 使用正斜杠(/)來分割目錄路徑,微軟使用了反斜杠(\),原因是,正斜杠已經被用于表示命令行選項,所以微軟選擇了反斜杠。

編程語言中一些令人抓狂的規則

        反斜杠在 Unix 和其他的例如 Perl 和 C 語言中主要是用來區分后后面緊跟著的字符,所以這給程序員帶來的痛苦就是要經常在正斜杠和反斜杠之間來來回回的仔細的檢查,以免出錯。

“回想起來,我覺得這是一個可怕的決定,但是換成是我的話,當時可能會做出同樣的舉動。”——Dave Lindbergh

        4. Python 使用縮進表示塊

        絕大多數編程語言使用明確的分隔符,例如用大括號來表示語句的分組,而 Python 卻不是這樣的,它使用前導空白(空格和制表符)來表示哪一個塊屬于哪一行代碼。

編程語言中一些令人抓狂的規則

        事實上,只有那些經驗豐富的 Python 程序員比較傾向于使用這個功能,而對于那些新手或者是不常使用它的程序員來說,別提有多惱怒了,尤其是剪切代碼、粘貼代碼、改變平臺,或者是重構代碼的時候。

“在兩個平臺之間轉換的過程中,你會發現這真是編程語言里的極品功能啊!”——Joe Zitzelberger

        5. Tony Hoare 發明了空引用

        在 1965 的時候,英國著名計算機科學家 Tony Hoare 將空引用概念引入到 ALGOL W 語言里,以確保所有使用的引用內容都是安全的。一直到現在,這一發明都存在于大部分編程語言里。

編程語言中一些令人抓狂的規則

        編譯器是不會抱怨空指針的,但是想要廢棄一個可能會導致運行時錯誤或系統崩潰的引用的話,那么程序員必須設法做一些防御措施或者是調試工作。

“我認為它是一個導致數十億美元損失的錯誤。”——Tony Hoare

        6. JavaScript 自動插入分號

        JavaScript 中分號表示語句結束,但 JavaScript 會自動的在它認為合適的地方插入分號。例如在程序結尾,或者在緊接 1 個新行的 return 語句后面。

編程語言中一些令人抓狂的規則

        在某些情況下,return 后面可能會有大括號和新的代碼塊,這種情況下,如果自動插入分號,就有可能導致語法錯誤

“這一功能著實讓開發者的工作出現了一點混亂,尤其是當你為一個生產環境壓縮代碼的時候。”——Mike Nelson

        7. 如何表示日期

        在如何表示日期這一問題上已經產生過很多比較有效地選擇方案了,例如只使用兩個數字或者是更少的數字來表示年份,可以被四整除的年份是閏年,或 者是像 Unix 系統那樣提供的基本時間服務是國際標準時間公元 1970 年 1 月 1 日 00:00:00 以來經過的分秒,這種秒數是以數據類型 time_t表示的。我們稱它們為日歷時間,日歷時間包括時間和日期。

編程語言中一些令人抓狂的規則

        只使用兩個數字或者是更少的數字來表示年份就會導致眾所周知的 Y2K 問題,計算閏年的過程中也是會出現很多 bug,有些系統照樣會出現 Y2K38 問題。

“在 20 世紀 60 年代的時候,內存的價值大約為 1 美元/字節。所以,在 60 年代或者是在 80 年代的時候使用 2 個數字來表達年份是很合理的。可問題就在于是穩定而精確的軟件所運行的時間完全超出了其預期設計的壽命時間。”——Fred Krampe

</blockquote>

來自: www.iteye.com

                    <span id="shareA4" class="fl">                          </span>
 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!