1. 寫出一手爛代碼的 19 條準(zhǔn)則

        共 2023字,需瀏覽 5分鐘

         ·

        2020-02-25 23:21


        轉(zhuǎn)載自機(jī)器之心

        閱讀本文大概需要 5 分鐘。


        要是想寫個爛代碼,我們只需遵守這十九條準(zhǔn)則?

        fa21e4b63b0d0b6ba2579cb4cff26145.webp


        「代碼寫得好」是對機(jī)器學(xué)習(xí)研究者及開發(fā)者最好的贊揚(yáng)。其第一層意思是說,你的模型非常好,有自己的理解與修正;第二層意思是說代碼的結(jié)構(gòu)、命名規(guī)則、編寫邏輯都非常優(yōu)秀。


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



        90c70e06f99ee0f6a75d6b2c8f38f0cc.webp

        在精簡與易讀之間做權(quán)衡,第一種方法根據(jù)列表推導(dǎo)式能獲得更精簡的代碼,但第二種方法更易讀。


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


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


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


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


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


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


        第一條:打字越少越好


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


        708d65b20f943336c61a07340779be41.webp


        第二條:變量/函數(shù)混合命名風(fēng)格


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


        4ae32e24c8cf7c65966fcedb3428f362.webp


        第三條:不要寫注釋


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


        70801ac5e1f4c12f15c635d350d9d8be.webp


        第四條:使用母語寫注釋


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


        a584642ddadc3ba2c55d05894a07524c.webp


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


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


        8d3a2eacc4c96a2e47909b37549dc730.webp


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


        如果一系列參數(shù)與方法都是一起實現(xiàn)的,那么代碼也要寫在一起。


        48d2c4ac3126a4856531c1105f96c537.webp


        第七條:發(fā)現(xiàn)錯誤要保持靜默


        當(dāng)你發(fā)現(xiàn)某些錯誤時,其他人不需要了解它,因此不需要打印出日志或 Traceback。


        bd6575540652ce201fe13b7731b01b35.webp


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


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


        6f91bbe4efdc8abae8513b3030eceb5d.webp


        第九條:構(gòu)建備用變量


        以防萬一,我們需要創(chuàng)建一些備用變量,在需要時隨時調(diào)用它們。


        5accebed5dd1f416d2112082feac5759.webp


        第十條:Type 使用需謹(jǐn)慎


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


        ab0de2c688a72cf5e24705bf6a742fe8.webp


        第十一條:準(zhǔn)備「Plan B」


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


        2d7f468a892f61340947a22cb581d919.webp


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


        如果代碼有一些嵌套結(jié)構(gòu),或者說縮進(jìn)空行的結(jié)構(gòu),三角法則是最漂亮的。


        44e5586ac09c5b0429d16ec76f99abb3.webp


        第十三條:混合縮進(jìn)


        我們需要避免采用縮進(jìn),因為縮進(jìn)會使復(fù)雜代碼在編輯器中占用更多的空間。如果一定要采用縮進(jìn),那么就使用混合縮進(jìn)策略。當(dāng)然,這種策略在 Python 中是行不通的,因為它靠縮進(jìn)來確定代碼結(jié)構(gòu)。


        d8c651575e86253922dfe9efbc5e6097.webp


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


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


        ec9fc8c7f5975596b4e87da1bb49ed28.webp


        第十五條:長函數(shù)比短函數(shù)好


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


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


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


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


        第十七條:盡量避免重復(fù)代碼


        按你的想法寫代碼,尤其是在小團(tuán)隊中,畢竟這是「自由」準(zhǔn)則。


        第十八條:構(gòu)建新項目不需要 README 文檔


        在項目前期,我們可以暫時保持這種狀態(tài)。


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


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


        相關(guān)閱讀:




        文為機(jī)器之心報道,轉(zhuǎn)載請聯(lián)系本公眾號獲得授權(quán)
        ?------------------------------------------------[email protected]投稿或?qū)で髨蟮溃篶ontent@jiqizhixin.com& 商務(wù)合作:[email protected]
        瀏覽 40
        點(diǎn)贊
        評論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報
        評論
        圖片
        表情
        推薦
        點(diǎn)贊
        評論
        收藏
        分享

        手機(jī)掃一掃分享

        分享
        舉報
          
          

            1. 女同性毛片60分钟 | 色哟哟啪啪成人网站免费 | 我要看操逼毛片 | 91视频app污 | 大香蕉尹人在看 |