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

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

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

垃圾代碼應該怎么寫

strongerHuang ? 來源: strongerHuang ? 作者: strongerHuang ? 2021-01-18 11:08 ? 次閱讀

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

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

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

這是一個你的項目應該遵循的垃圾代碼書寫準則的列表:

以一種代碼已經(jīng)被混淆的方式命名變量

如果我們鍵入的東西越少,那么就有越多的時間去思考代碼邏輯等問題。

變量/函數(shù)混合命名風格

為不同慶祝一下。

Good

let wWidth = 640;
let w_height = 480;

Bad

let windowWidth = 640;
let windowHeight = 480;

不要寫注釋

反正沒人會讀你的代碼。

Good

const cdr = 700;

Bad

更多時候,評論應該包含一些“為什么”,而不是一些“是什么”。如果“什么”在代碼中不清楚,那么代碼可能太混亂了。

// 700ms的數(shù)量是根據(jù)UX A/B測試結(jié)果進行經(jīng)驗計算的。
// @查看: <詳細解釋700的一個鏈接>
const callbackDebounceRate = 700;

使用母語寫注釋

如果您違反了“無注釋”原則,那么至少嘗試用一種不同于您用來編寫代碼的語言來編寫注釋。如果你的母語是英語,你可能會違反這個原則。

Good

// Закрива?мо модальне в?конечко при виникненн? помилки.
toggleModal(false);

Bad

// 隱藏錯誤彈窗
toggleModal(false);

盡可能混合不同的格式

為不同慶祝一下。

Good

let i = ['tomato', 'onion', 'mushrooms'];
let d = [ "ketchup", "mayonnaise" ];

Bad

let ingredients = ['tomato', 'onion', 'mushrooms'];
let dressings = ['ketchup', 'mayonnaise'];

盡可能把代碼寫成一行

Good

document.location.search.replace(/(^?)/,'').split('&').reduce(function(o,n){n=n.split('=');o[n[0]]=n[1];return o},{})

Bad

document.location.search
  .replace(/(^?)/, '')
  .split('&')
  .reduce((searchParams, keyValuePair) => {
    keyValuePair = keyValuePair.split('=');
    searchParams[keyValuePair[0]] = keyValuePair[1];
    return searchParams;
  },
  {}
)

不要處理錯誤

無論何時發(fā)現(xiàn)錯誤,都沒有必要讓任何人知道它。沒有日志,沒有錯誤彈框。

Good

try {
  // 意料之外的情況。
} catch (error) {
  // tss... 
}

Bad

try {
  // 意料之外的情況。
} catch (error) {
  setErrorMessage(error.message);
  // and/or
  logError(error);
}

廣泛使用全局變量

全球化的原則。

Good

let x = 5;

function square() {
  x = x ** 2;
}

square(); // 現(xiàn)在x是25

Bad

let x = 5;

function square(num) {
  return num ** 2;
}

x = square(x); // 現(xiàn)在x是25

創(chuàng)建你不會使用的變量

以防萬一。

Good

function sum(a, b, c) {
  const timeout = 1300;
  const result = a + b;
  return a + b;
}

Bad

function sum(a, b) {
  return a + b;
}

如果語言允許,不要指定類型和/或不執(zhí)行類型檢查。

Good

function sum(a, b) {
  return a + b;
}

// 在這里享受沒有注釋的快樂
const guessWhat = sum([], {}); // -> "[object Object]"
const guessWhatAgain = sum({}, []); // -> 0

Bad

function sum(a: number, b: number): ?number {
  // 當我們在JS中不做置換和/或流類型檢查時,覆蓋這種情況。
  if (typeof a !== 'number' && typeof b !== 'number') {
    return undefined;
  }
  return a + b;
}

// 這個應該在轉(zhuǎn)換/編譯期間失敗。
const guessWhat = sum([], {}); // -> undefined

你應該有不能到達的代碼

這是你的 “Plan B”.

Good

function square(num) {
  if (typeof num === 'undefined') {
    return undefined;
  }
  else {
    return num ** 2;
  }
  return null; // 這就是我的"Plan B".
}

Bad

function square(num) {
  if (typeof num === 'undefined') {
    return undefined;
  }
  return num ** 2;
}

三角法則

就像鳥巢,鳥巢,鳥巢。

Good

function someFunction() {
  if (condition1) {
    if (condition2) {
      asyncFunction(params, (result) => {
        if (result) {
          for (;;) {
            if (condition3) {
            }
          }
        }
      })
    }
  }
}

Bad

async function someFunction() {
  if (!condition1 || !condition2) {
    return;
  }
  
  const result = await asyncFunction(params);
  if (!result) {
    return;
  }
  
  for (;;) {
    if (condition3) {
    }
  }
}

混合縮進

避免縮進,因為它們會使復雜的代碼在編輯器中占用更多的空間。如果你不喜歡回避他們,那就和他們搗亂。

Good

const fruits = ['apple',
  'orange', 'grape', 'pineapple'];
  const toppings = ['syrup', 'cream', 
                    'jam', 
                    'chocolate'];
const desserts = [];
fruits.forEach(fruit => {
toppings.forEach(topping => {
    desserts.push([
fruit,topping]);
    });})

Bad

const fruits = ['apple', 'orange', 'grape', 'pineapple'];
const toppings = ['syrup', 'cream', 'jam', 'chocolate'];
const desserts = [];

fruits.forEach(fruit => {
  toppings.forEach(topping => {
    desserts.push([fruit, topping]); 
  });
})

不要鎖住你的依賴項

以非受控方式更新每個新安裝的依賴項。為什么堅持使用過去的版本,讓我們使用最先進的庫版本。

Good

$ ls -la

package.json

Bad

$ ls -la

package.json
package-lock.json

函數(shù)長的比短的好

不要把程序邏輯分成可讀的部分。如果IDE的搜索停止,而您無法找到所需的文件或函數(shù),該怎么辦?

一個文件中10000行代碼是OK的。

一個函數(shù)體有1000行代碼是OK的。

在一個‘ service.js ’ 中處理許多服務(第三方庫和內(nèi)部庫、一些工具、手寫的數(shù)據(jù)庫ORM和jQuery滑塊)? 這是OK的。

不要測試你的代碼

這是重復且不需要的工作。

避免代碼風格統(tǒng)一

編寫您想要的代碼,特別是在一個團隊中有多個開發(fā)人員的情況下。這是“自由”原則。

構(gòu)建新項目不需要 README 文檔

一開始我們就應該保持。

保存不必要的代碼

不要刪除不用的代碼,最多注釋掉。

責任編輯:xj

原文標題:GitHub這份垃圾代碼書寫準則,火了

文章出處:【微信公眾號:strongerHuang】歡迎添加關注!文章轉(zhuǎn)載請注明出處。


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

    關注

    30

    文章

    4823

    瀏覽量

    68939
  • GitHub
    +關注

    關注

    3

    文章

    473

    瀏覽量

    16534

原文標題:GitHub這份垃圾代碼書寫準則,火了

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關推薦

    垃圾短信?手機自動識別垃圾短信邏輯的分析

    作者:京東科技 賈玉龍 1 背景 隨著智能手機的普及和移動互聯(lián)網(wǎng)的發(fā)展,短信作為一種傳統(tǒng)的通訊方式,仍然保持著其獨特的地位。然而,隨著垃圾短信的泛濫,手機自動識別垃圾短信的技術也在不斷進步。對于提供
    的頭像 發(fā)表于 12-16 10:19 ?281次閱讀

    FlexLua低代碼零基礎開發(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 ?1447次閱讀
    FlexLua低<b class='flag-5'>代碼</b>零基礎開發(fā)智能<b class='flag-5'>垃圾</b>桶產(chǎn)品原型(接入機智云)

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

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

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

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

    基于Vision Board上的openMV垃圾分類

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

    智能垃圾回收箱功能實驗

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

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

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

    如何提升代碼質(zhì)量與效率的秘訣

    提高編程能力其實沒有捷徑,最佳方式就是多代碼。 不過,除了大量代碼,提升編程能力還需要大量閱讀別人
    的頭像 發(fā)表于 04-28 14:53 ?436次閱讀
    如何提升<b class='flag-5'>代碼</b>質(zhì)量與效率的秘訣

    垃圾中轉(zhuǎn)站無人值守物聯(lián)網(wǎng)解決方案

    隨著城市化程度越來越高,城鄉(xiāng)生活垃圾日益增多,生活垃圾中轉(zhuǎn)站運行和管理問題越來越突出,人力成本高、設備故障運維滯后、運營效率差等問題,成為垃圾中轉(zhuǎn)站管理中繞不開的難題。 垃圾中轉(zhuǎn)站通常
    的頭像 發(fā)表于 04-19 11:22 ?756次閱讀
    <b class='flag-5'>垃圾</b>中轉(zhuǎn)站無人值守物聯(lián)網(wǎng)解決方案

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

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

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

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

    阿里云內(nèi)部全面推行AI代碼

    阿里云正在內(nèi)部全面推行 AI 編程,使用通義靈碼輔助程序員代碼、讀代碼、查 BUG、優(yōu)化代碼等。
    的頭像 發(fā)表于 04-07 09:22 ?591次閱讀

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

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

    AI垃圾溢出識別攝像機

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

    如何使用Arduino制作智能垃圾

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