精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

垃圾代碼應該怎么寫

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

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

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

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

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

以一種代碼已經被混淆的方式命名變量

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

變量/函數混合命名風格

為不同慶祝一下。

Good

let wWidth = 640;
let w_height = 480;

Bad

let windowWidth = 640;
let windowHeight = 480;

不要寫注釋

反正沒人會讀你的代碼。

Good

const cdr = 700;

Bad

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

// 700ms的數量是根據UX A/B測試結果進行經驗計算的。
// @查看: <詳細解釋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;
  },
  {}
)

不要處理錯誤

無論何時發現錯誤,都沒有必要讓任何人知道它。沒有日志,沒有錯誤彈框。

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(); // 現在x是25

Bad

let x = 5;

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

x = square(x); // 現在x是25

創建你不會使用的變量

以防萬一。

Good

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

Bad

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

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

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;
}

// 這個應該在轉換/編譯期間失敗。
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

函數長的比短的好

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

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

一個函數體有1000行代碼是OK的。

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

不要測試你的代碼

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

避免代碼風格統一

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

構建新項目不需要 README 文檔

一開始我們就應該保持。

保存不必要的代碼

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

責任編輯:xj

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

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


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

    關注

    30

    文章

    4751

    瀏覽量

    68358
  • GitHub
    +關注

    關注

    3

    文章

    466

    瀏覽量

    16387

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

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

收藏 人收藏

    評論

    相關推薦

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

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

    基于PYNQ的智能垃圾分類系統

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

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

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

    基于Vision Board上的openMV垃圾分類

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

    智能垃圾回收箱功能實驗

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

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

    隨著城市功能的不斷豐富,城市管理工作也從粗放到精細、從純人工管理到數字化應用逐漸轉變。近日,某小區垃圾滿溢監測“神器”上線,能夠實時監控區內果皮箱的數量、位置、垃圾量情況,讓垃圾清運更高
    的頭像 發表于 05-13 09:37 ?334次閱讀
    <b class='flag-5'>垃圾</b>清運以及<b class='flag-5'>垃圾</b>處理“神器”讓<b class='flag-5'>垃圾</b>清運更高效。

    如何提升代碼質量與效率的秘訣

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

    垃圾中轉站無人值守物聯網解決方案

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

    智能垃圾回收箱控制系統硬件設計

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

    OpenHarmony南向開發案例:【智能垃圾桶】

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

    基于機智云物聯網平臺的智能垃圾回收箱與控制系統研究

    軟件設計流程分析,根據硬件部分的原理設計出軟件流程圖,編制軟件程序代碼。 (3)智能垃圾回收箱的設備信息、用戶信息,APP 綁定、箱體定位等功能,通過云平臺實現。云平臺可以對數據進行儲存、分析計算
    發表于 04-09 17:25

    阿里云內部全面推行AI代碼

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

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

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

    AI垃圾溢出識別攝像機

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

    如何使用Arduino制作智能垃圾

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