0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

十九條垃圾代碼書寫準則

Q4MP_gh_c472c21 ? 來源:機器之心 ? 作者:Jack-Cui ? 2022-05-18 14:59 ? 次閱讀

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

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

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

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

第一條:打字越少越好

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

b3c40a8e-d661-11ec-bce3-dac502259ad0.png

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

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

b3df8ea8-d661-11ec-bce3-dac502259ad0.png

第三條:不要寫注釋

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

b3f6656a-d661-11ec-bce3-dac502259ad0.png

第四條:使用母語寫注釋

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

b41e0d7c-d661-11ec-bce3-dac502259ad0.png

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

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

b4339a66-d661-11ec-bce3-dac502259ad0.png

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

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

b4508f90-d661-11ec-bce3-dac502259ad0.png

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

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

b46f2f40-d661-11ec-bce3-dac502259ad0.png

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

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

b47ff154-d661-11ec-bce3-dac502259ad0.png

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

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

b48ec166-d661-11ec-bce3-dac502259ad0.png

第十條:Type 使用需謹慎

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

b4a8045a-d661-11ec-bce3-dac502259ad0.png

第十一條:準備「Plan B」

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

b4cd01b0-d661-11ec-bce3-dac502259ad0.png

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

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

b4f73ade-d661-11ec-bce3-dac502259ad0.png

第十三條:混合縮進

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

b51160ee-d661-11ec-bce3-dac502259ad0.png

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

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

b52fe67c-d661-11ec-bce3-dac502259ad0.png

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

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

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

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

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

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

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

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

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

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

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

END 審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4700

    瀏覽量

    68117
  • GitHub
    +關(guān)注

    關(guān)注

    3

    文章

    461

    瀏覽量

    16337

原文標題:手把手教你寫出令人窒息的爛代碼

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    FlexLua低代碼零基礎(chǔ)開發(fā)智能垃圾桶產(chǎn)品原型(接入機智云)

    目標功能介紹基于功能強大的ShineBlink低代碼物聯(lián)網(wǎng)核心模組和靈活輕巧的Lua腳本編程語言實現(xiàn)如下功能。1、監(jiān)測和報警監(jiān)測圾桶內(nèi)的煙霧并聲光報警監(jiān)測圾桶內(nèi)的酒精等有害氣體并聲光報警監(jiān)測垃圾桶內(nèi)
    的頭像 發(fā)表于 07-11 08:11 ?1310次閱讀
    FlexLua低<b class='flag-5'>代碼</b>零基礎(chǔ)開發(fā)智能<b class='flag-5'>垃圾</b>桶產(chǎn)品原型(接入機智云)

    基于PYNQ的智能垃圾分類系統(tǒng)

    第一部分 設(shè)計概述 /Design Introduction 1.1 設(shè)計目的 隨著現(xiàn)代社會的高速發(fā)展,其帶來的環(huán)境壓力也越來越大,對于日益劇增的垃圾產(chǎn)量已經(jīng)成為世界關(guān)注的焦點。垃圾分類成為
    發(fā)表于 07-09 18:44

    UART傳輸在控制臺中顯示垃圾值是哪里的問題?

    的控制臺窗口上顯示的不是"Hello World" ,而是垃圾字符。 我檢查了流程,發(fā)現(xiàn)與示例代碼相似,如波特率設(shè)置正確,緩沖區(qū)流程也正確。 錯誤還可能出現(xiàn)在哪里?
    發(fā)表于 07-02 08:24

    淺談EMC設(shè)計準則

    在日益數(shù)字化的時代,電子設(shè)備的設(shè)計已成為現(xiàn)代生活中不可或缺的一部分。但隨之而來的是電磁兼容性(EMC)問題的日益凸顯。EMC設(shè)計準則的制定和遵循對于確保設(shè)備在各種環(huán)境中穩(wěn)定運行并且不會干擾其他設(shè)備
    的頭像 發(fā)表于 06-18 14:59 ?2173次閱讀
    淺談EMC設(shè)計<b class='flag-5'>準則</b>

    基于Vision Board上的openMV垃圾分類

    通過在Vision Board部署openMV實現(xiàn)垃圾分類。
    的頭像 發(fā)表于 06-17 10:49 ?512次閱讀
    基于Vision Board上的openMV<b class='flag-5'>垃圾</b>分類

    智能垃圾回收箱功能實驗

    需要系統(tǒng)地介紹智能垃圾回收箱軟件硬件設(shè)計完成后的設(shè)備運行狀況,包括正常工作和問題調(diào)試。同時,也要描述當所有設(shè)備正常工作時智能垃圾回收箱的操作流程。01硬件模塊的試驗在智能垃圾回收箱的正常運轉(zhuǎn)
    的頭像 發(fā)表于 05-24 08:10 ?366次閱讀
    智能<b class='flag-5'>垃圾</b>回收箱功能實驗

    在STVD書寫代碼的時候,一寫到“{}”就自動頂格了怎么解決?

    在STVD書寫代碼的時候,一寫到“{}”就自動頂格了,好煩哪- -! 不知道哪里可以更改這個設(shè)置?
    發(fā)表于 05-17 07:34

    垃圾清運以及垃圾處理“神器”讓垃圾清運更高效。

    隨著城市功能的不斷豐富,城市管理工作也從粗放到精細、從純?nèi)斯す芾淼綌?shù)字化應(yīng)用逐漸轉(zhuǎn)變。近日,某小區(qū)垃圾滿溢監(jiān)測“神器”上線,能夠?qū)崟r監(jiān)控區(qū)內(nèi)果皮箱的數(shù)量、位置、垃圾量情況,讓垃圾清運更高
    的頭像 發(fā)表于 05-13 09:37 ?286次閱讀
    <b class='flag-5'>垃圾</b>清運以及<b class='flag-5'>垃圾</b>處理“神器”讓<b class='flag-5'>垃圾</b>清運更高效。

    智能垃圾回收箱控制系統(tǒng)硬件設(shè)計

    智能高效遠程控制智能垃圾桶回收箱控制系統(tǒng)硬件部分的選型與設(shè)計是整個產(chǎn)品的基礎(chǔ),所有功能的實現(xiàn)都要圍繞其進行開發(fā)。本章對智能垃圾回收箱控制系統(tǒng)的硬件進行詳細設(shè)計。智能垃圾回收箱運行時,通過掃描模塊進行
    的頭像 發(fā)表于 04-13 08:10 ?732次閱讀
    智能<b class='flag-5'>垃圾</b>回收箱控制系統(tǒng)硬件設(shè)計

    OpenHarmony南向開發(fā)案例:【智能垃圾桶】

    智能垃圾桶可以通過數(shù)字管家應(yīng)用來監(jiān)測垃圾桶當前可用容量,提醒主人及時處理垃圾;通過日程管家可以實現(xiàn)和其他智能設(shè)備聯(lián)動。
    的頭像 發(fā)表于 04-11 16:01 ?455次閱讀
    OpenHarmony南向開發(fā)案例:【智能<b class='flag-5'>垃圾</b>桶】

    瑞薩推出智能垃圾箱解決方案

    隨著城市化進程的加速推進,城市垃圾處理問題愈發(fā)凸顯。傳統(tǒng)的垃圾收集方式不僅效率低下,成本高昂,而且往往伴隨著嚴重的環(huán)境污染問題。在這一背景下,瑞薩推出的智能垃圾箱解決方案以其環(huán)保、高效的特性,為城市
    的頭像 發(fā)表于 03-16 10:02 ?882次閱讀

    AI垃圾溢出識別攝像機

    隨著城市化進程的加快,垃圾處理成為城市管理中的一項重要工作。然而,垃圾桶溢出現(xiàn)象經(jīng)常發(fā)生,給城市環(huán)境衛(wèi)生和市民生活帶來不便。為了解決這一問題,AI垃圾溢出識別攝像機應(yīng)運而生,利用人工智能技術(shù),實現(xiàn)
    的頭像 發(fā)表于 03-13 11:04 ?425次閱讀
    AI<b class='flag-5'>垃圾</b>溢出識別攝像機

    如何使用Arduino制作智能垃圾

    在這個項目中,我將向您展示如何使用Arduino制作智能垃圾箱,當您帶著垃圾接近時,垃圾箱的蓋子會自動打開。
    的頭像 發(fā)表于 02-11 12:22 ?2666次閱讀
    如何使用Arduino制作智能<b class='flag-5'>垃圾</b>箱

    東莞鵬利全自動垃圾桶清洗機——垃圾桶清洗演示

    智能垃圾
    鑫金暉
    發(fā)布于 :2023年11月09日 14:04:03