日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

如果說到什么是好代碼,我們肯定都能說出一堆規(guī)則,例如使用一致的格式和縮進、使用清晰的變量名和方法名、在必要時提供文檔與注釋、不要過度精簡代碼等等。

 

但是對于什么是爛代碼,你有比較清晰的認識嗎?

 

在 GitHub 上有一個新項目,它描述了「最佳垃圾代碼」的十九條關鍵準則。從變量命名到注釋編寫。這些準則將指導你寫出最亮眼的爛代碼。

 

為了保持與原 GitHub 項目一致的風格,下文沒有進行轉換。讀者們可以以相反的角度來理解所有觀點,這樣就能完美避免寫出垃圾代碼。

 

repo 地址: https://github.com/trekhleb/state-of-the-art-shitcode

 

當然,以下十九條垃圾代碼書寫準則并沒有面面俱到,如果讀者們發(fā)現有一些難以忍受的爛代碼習慣,也可以留言發(fā)表你的看法。

 

第一條:打字越少越好

 

如果我們鍵入的東西越少,那么就有越多的時間去思考代碼邏輯等問題。如下所示,「Good」表示遵循該規(guī)則的示例,Bad 表示沒遵循該規(guī)則的示例。

 

手牽手教你寫代碼,從入門到精通

 


第二條:****變量/函數混合命名風格我們需要混合命名方法與變量,這樣才能體現命名的多樣性。

 

手牽手教你寫代碼,從入門到精通

 

 

第三條:****不要寫注釋反正代碼都看得懂,為什么要寫注釋?或者說,反正沒人看我的代碼,為什么要寫注釋?

 

手牽手教你寫代碼,從入門到精通

 

 

第四條:****使用母語寫注釋如果你違反了第三條規(guī)則,那么至少寫注釋需要用你的母語或者其它語言。如果你的母語是英語,那么你也算違反了這條規(guī)則。既然編程語言絕大多數都是用英文,那么為什么不用其它語言注釋一下?

 

手牽手教你寫代碼,從入門到精通

 

 

第五條:****盡可能混合不同的格式同樣,為了代碼的多樣性,我們需要盡可能混合不同的格式,例如單引號或雙引號。如果它們的語義相同,那就應該混用。

 

手牽手教你寫代碼,從入門到精通

 

 

第六條:****盡可能把代碼寫成一行如果一系列參數與方法都是一起實現的,那么代碼也要寫在一起。

 

手牽手教你寫代碼,從入門到精通

 

 

第七條:****發(fā)現錯誤要保持靜默當你發(fā)現某些錯誤時,其他人不需要了解它,因此不需要打印出日志或 Traceback。

 

手牽手教你寫代碼,從入門到精通

 

 

第八條:****廣泛使用全局變量使用全局變量,是面向「全球化」不可或缺的部分。

 

手牽手教你寫代碼,從入門到精通

 

 

第九條:****構建備用變量以防萬一,我們需要創(chuàng)建一些備用變量,在需要時隨時調用它們。

 

手牽手教你寫代碼,從入門到精通

 

 

第十條:****Type 使用需謹慎一般不要指定變量類型或者經常做類型檢查,無類型才是最好的類型。

 

手牽手教你寫代碼,從入門到精通

 

 

第十一條:****準備「Plan B」你需要準備一些運行不到的代碼(unreachable code),它們可以作為你的「Plan B」。

 

手牽手教你寫代碼,從入門到精通

 

 

第十二條:****嵌套的三角法則如果代碼有一些嵌套結構,或者說縮進空行的結構,三角法則是最漂亮的。

 

手牽手教你寫代碼,從入門到精通

 

 

第十三條:****混合縮進我們需要避免采用縮進,因為縮進會使復雜代碼在編輯器中占用更多的空間。如果一定要采用縮進,那么就使用混合縮進策略。當然,這種策略在 Python 中是行不通的,因為它靠縮進來確定代碼結構。

 

手牽手教你寫代碼,從入門到精通

 

 

第十四條:****不要鎖住依賴項每一次要安裝新庫時,更新已有的依賴項。為什么要維持之前的版本呢,我們需要時刻保持最新的第三方代碼庫。

 

手牽手教你寫代碼,從入門到精通

 

 

第十五條:****長函數比短函數好不要將程序整體邏輯分割為一些代碼塊,要是 IDE 突然不行了,它找不到必要的文件或函數怎么辦。因此把代碼寫在一個主體函數中,并且不再維護額外的函數導入或代碼文件,那么這樣的方法是最穩(wěn)定的。單個文件一萬行代碼是沒問題的,單個函數一千行代碼也是沒問題的。

 

第十六條:****代碼不需要做特定測試這些測試通常是重復且無意義的工作。

 

第十七條:****盡量避免重復代碼按你的想法寫代碼,尤其是在小團隊中,畢竟這是「自由」準則。

 

第十八條:****構建新項目不需要 README 文檔在項目前期,我們可以暫時保持這種狀態(tài)。

 

第十九條:****保存不必要的代碼在寫代碼的過程中,經常會產生很多測試代碼。這些代碼也是非常重要的資料,因此不能刪除掉,最多只能注釋掉。

分享到:
標簽:代碼
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰(zhàn)2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定