成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

寫出一手爛代碼的19條準則

開發 前端
要是想寫個爛代碼,我們只需遵守這十九條準則?「代碼寫得好」是對機器學習研究者及開發者比較好的贊揚。其第一層意思是說,你的模型非常好,有自己的理解與修正;第二層意思是說代碼的結構、命名規則、編寫邏輯都非常優秀。

「代碼寫得好」是對機器學習研究者及開發者比較好的贊揚。其第一層意思是說,你的模型非常好,有自己的理解與修正;第二層意思是說代碼的結構、命名規則、編寫邏輯都非常優秀。

[[314442]]

我們曾經將寫代碼比喻成寫文章:不僅需要有一個主旨,告訴別人代碼的作用是什么,同時還應該在精煉與易讀之間做權衡。代碼過于精煉,整體邏輯難以跟隨,代碼過于易讀,整體就顯得比較臃腫。

寫出一手爛代碼的19條準則

在精簡與易讀之間做權衡,第一種方法根據列表推導式能獲得更精簡的代碼,但第二種方法更易讀。

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

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

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

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

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

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

第一條:打字越少越好

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

寫出一手爛代碼的19條準則

第二條:變量/函數混合命名風格

我們需要混合命名方法與變量,這樣才能體現命名的多樣性。

寫出一手爛代碼的19條準則

第三條:不要寫注釋

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

寫出一手爛代碼的19條準則

第四條:使用母語寫注釋

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

寫出一手爛代碼的19條準則

第五條:盡可能混合不同的格式

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

寫出一手爛代碼的19條準則

第六條:盡可能把代碼寫成一行

如果一系列參數與方法都是一起實現的,那么代碼也要寫在一起。

寫出一手爛代碼的19條準則

第七條:發現錯誤要保持靜默

當你發現某些錯誤時,其他人不需要了解它,因此不需要打印出日志或 Traceback。

寫出一手爛代碼的19條準則

第八條:廣泛使用全局變量

使用全局變量,是面向「全球化」不可或缺的部分。

寫出一手爛代碼的19條準則

第九條:構建備用變量

以防萬一,我們需要創建一些備用變量,在需要時隨時調用它們。

寫出一手爛代碼的19條準則

第十條:Type 使用需謹慎

一般不要指定變量類型或者經常做類型檢查,無類型才是最好的類型。

寫出一手爛代碼的19條準則

第十一條:準備「Plan B」

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

寫出一手爛代碼的19條準則

第十二條:嵌套的三角法則

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

寫出一手爛代碼的19條準則

第十三條:混合縮進

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

寫出一手爛代碼的19條準則

第十四條:不要鎖住依賴項

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

寫出一手爛代碼的19條準則

第十五條:長函數比短函數好

不要將程序整體邏輯分割為一些代碼塊,要是 IDE 突然不行了,它找不到必要的文件或函數怎么辦。因此把代碼寫在一個主體函數中,并且不再維護額外的函數導入或代碼文件,那么這樣的方法是最穩定的。

單個文件一萬行代碼是沒問題的,單個函數一千行代碼也是沒問題的。

第十六條:代碼不需要做特定測試

這些測試通常是重復且無意義的工作。

第十七條:盡量避免重復代碼

按你的想法寫代碼,尤其是在小團隊中,畢竟這是「自由」準則。

第十八條:構建新項目不需要 README 文檔

在項目前期,我們可以暫時保持這種狀態。

第十九條:保存不必要的代碼

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

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2020-02-27 16:17:31

代碼規范codegithub

2020-07-10 15:41:41

Python代碼編程語言

2023-07-16 22:57:38

代碼場景業務

2018-09-04 15:45:58

Python代碼編程語言

2019-05-06 11:06:30

PyTorch深度學習框架

2015-07-23 09:30:43

爛代碼程序員

2019-11-15 15:09:27

Python代碼優雅

2023-08-24 21:49:54

人工智能高端算法工程師

2013-04-17 10:30:07

GlassGoogle

2010-09-09 15:21:17

丁磊

2019-12-16 14:04:48

MySQL數據庫SQL

2023-11-10 16:08:23

SQL數據庫

2019-10-24 15:23:04

SQL優化數據庫

2020-05-22 08:24:21

SQLMySQL數據庫

2023-09-03 18:44:50

AI運營商

2011-06-24 14:48:08

英特爾網卡

2012-05-21 15:34:48

H3C無線路由

2017-07-04 09:49:36

ActivityAndroidLife場景

2023-09-22 12:04:53

Java代碼

2015-05-18 15:37:28

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 激情五月激情综合网 | 亚洲免费网址 | 一级毛片视频在线 | 国产伦一区二区三区久久 | 精品成人av| 亚洲欧洲一区二区 | 免费黄色在线观看 | 91精品国产综合久久久密闭 | 亚洲视频三| 性色av一区二区三区 | 毛片免费看的 | 国产精品av久久久久久毛片 | 欧美高清一级片 | 欧美 日韩 中文 | av中文字幕在线播放 | 欧美一级在线观看 | 亚洲男人天堂av | 成人精品 | 亚洲精品免费视频 | 色综合久久久久 | 国产jizz女人多喷水99 | 黑人精品欧美一区二区蜜桃 | 免费一区在线观看 | 涩涩视频在线播放 | 精品一区二区三区不卡 | av在线播放国产 | 精产嫩模国品一二三区 | 欧美性网 | 国产精品毛片av一区 | 午夜在线精品 | 欧美视频在线看 | 成人久久18免费网站图片 | 久久久久一区二区三区四区 | 激情欧美日韩一区二区 | 日韩精品一区二区三区 | 五月天天丁香婷婷在线中 | 欧美电影免费网站 | 午夜影院在线观看 | 色视频在线播放 | 欧美综合一区二区三区 | 久久一区精品 |