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

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

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

分享編程的七宗罪,也許對你會有所啟發(fā)

DPVg_AI_era ? 來源:lq ? 2019-02-20 09:05 ? 次閱讀

代碼千萬行,注釋第一行;編程不規(guī)范,同事兩行淚。本文分享了編程的七宗罪,也許對你會有所啟發(fā)。

編程江湖中一直盛傳著一個段子,那就是要問程序員最討厭哪 4 件事?那必須是:

寫注釋、寫文檔、別人不寫注釋、別人不寫文檔。

更甚者,在《流浪地球》形成刷屏之勢之后,仿其而出的 “代碼千萬行,注釋第一行;編程不規(guī)范,同事兩行淚” 在技術(shù)圈中開始盛傳,由此可見對于所有的程序員來說這是多么痛苦的事情。

本文作者 —— 全棧開發(fā)者 Nitin Sharma 分享了編程的七宗罪,也許對你會有所啟發(fā)。

以下為譯文:

還有什么事情比自己動手去創(chuàng)造更有趣?看著你發(fā)明的東西慢慢地進入生活?我們?nèi)祟悾侨f物之主,是造物主。

但是在數(shù)字化時代,發(fā)明創(chuàng)造的方式發(fā)生了變化?,F(xiàn)在,我們都創(chuàng)造數(shù)字化產(chǎn)品。我們建網(wǎng)站、寫軟件來滿足我們的需求。雖然我們創(chuàng)造不再依賴于我們的創(chuàng)造力,但是我們?nèi)匀豢梢耘c藝術(shù)家其名。

編程的世界非常地寬廣,涉及重多領(lǐng)域,我們有很多選擇。你可以選擇使用函數(shù)式編程,還是使用面向?qū)ο缶幊??你可以選擇做服務(wù)端還是客戶端?那么,你心中已經(jīng)有抉擇了嗎?下面,有 100 種編程語言,可以用來實現(xiàn)你的需求。

語言、框架、庫都在逐漸增多。你可以通過多種方式完成相同的代碼功能。雖然這些語言可能差別很大,但是大多數(shù)語言都遵循相同的思想。所以,他們也會出現(xiàn)相同的問題。

以下是編程七宗罪,你可以想辦法避免他們發(fā)生。雖然我不是基督教徒,但是我也喜歡定義七宗罪。

01. 協(xié)作時不使用版本控制

上帝保佑,我們有版本控制工具。如我所說,如果我們沒有像 Git 這種版本管理工具,代碼的世界將變得異常艱難。版本控制讓我們在協(xié)作的時候,修改或移動變得非常簡單。

想像一下,我們坐在電腦前,手動檢查并合并文件,為不同的版本保存不同的文件夾。這樣做是非常低效的,并且很不可靠。幸運的是,我們有 Git 和其它版本控制工具,來幫我們完成這個事情。

我參與過沒有版本控制的項目,那簡直就是一場惡夢。

02. 不使用合適的變量命名

我不知道為什么,身邊總有一些人,使用很短 / 隨機的名稱來給變量命名。當你的項目只有 10-20 行代碼,或者只是代碼片段時,你可以使用這種方式進行命名,但是在大項目中,不要這么做。不合適的命名,對可讀性和效率有致命的影響。

一個命名的簡單規(guī)則:你變量的名稱可以自解釋。當你看到它們的時候,就知道他們的用途。但是不要使用太長的名字來命名!保持命名簡短,并具有可讀性。

讓我們來找一找,你的代碼中用 a , b, c 命名的代碼。

03. 使用過多的依賴,不經(jīng)思考直接升級

GitHub 上面有多少個開源項目?已經(jīng)多到我們數(shù)不清了。這些開源庫使開發(fā)者的工作變得更加容易,節(jié)約我們的時間。

但是使用過多的依賴庫會對整個項目帶來風(fēng)險。依賴庫越多,就意味著編譯時間和運行時間的加長。我們應(yīng)該在我們需要的地方添加對應(yīng)的依賴庫,而不要為了使用它而使用它。

所以,在升級之前,我們需要經(jīng)常去檢查依賴庫 / 插件的支持情況。我曾經(jīng)有一次,升級了 React,而沒有去檢查它對其它庫的影響。到如今,我依然認為這是我生命中最嚴重的錯誤之一。

04. 不自解釋的代碼

值得一提的是,沒有人想閱讀整個方法 / 文件來理解它是干什么用的。使用最少的代碼來實現(xiàn)功能,但是不要讓別人或者是以后的自己,討厭你自己寫的東西。

我們應(yīng)該一直嘗試去寫自解釋的代碼。我們應(yīng)該讓我們的代碼,在第一次被看到的時候,就知道它是干什么用的。要完成這樣的代碼,我們需要進行正確的代碼重構(gòu),統(tǒng)一的語法,適當?shù)淖兞棵Q。必要的時候,還要給代碼添加注釋。

當然,也不要過多地書寫注釋,你不需要通過注釋解釋每一行代碼。最好用 1-2 行注釋,寫清楚重要部分的概述或說明。

05. 格式不一致

這個和第四點非常相近,格式不一致也會對可讀性和生產(chǎn)效率帶來巨大的影響。在項目中,選擇一個特定的命名規(guī)范并一直堅持下去,不要在中途改變它們。我個人更喜歡用大寫字母來命名文件,駝峰命名法來命名方法、變量等。但這些也會根據(jù)不同的語言而作出改變。

沒有比開發(fā)者格式化代碼更糟糕的事情。

此外,在代碼中,我們還需要使用相同的縮進格式。根據(jù)你的代碼樣式和選擇的語言,使用 2/4/8 個空格來做縮進。但無論你使用什么樣的格式,請堅持在整個項目中一直使用。

06. 不處理錯誤

畏懼它。逃避它。Bug 終會降臨! —— 滅霸

(譯者注:指 Bug 如影隨形,不休不止,像詛咒一樣。)

事情是這樣的,無論你是多么優(yōu)秀的程序員,你的代碼都有可能會出現(xiàn)問題,除非你寫的是像如下的這種代碼:

console.log("Yey")printf("Wow")

這些錯誤有可能是因為 API 錯誤引起的,也有可能是超時,類型錯誤,空值,或者只有上帝知道的原因。通常,這些會讓你的代碼出現(xiàn)問題。

在不同的語言中,處理錯誤的方式有很大的差異。但是一般情況下,在訪問數(shù)據(jù)之前都需要判斷數(shù)據(jù)否為空。在我的經(jīng)驗中,空指針比其它錯誤都多。

所以,在執(zhí)行數(shù)據(jù)處理的相關(guān)需求時,建議將代碼放到 try-catch 中,并處理對應(yīng)的異常,最后,不要忘記告訴用戶哪里出現(xiàn)了問題。如果在用戶按下按鈕和按鍵的時候不給用戶反饋,用戶將不知道發(fā)生了什么。給用戶錯誤提示,并告訴它下一步怎么做。

時刻記住滅霸的話。

07. 使用不當?shù)臄?shù)據(jù)類型 / 數(shù)據(jù)結(jié)構(gòu)

在不同的語言中,數(shù)據(jù)類型要求不一樣,強類型語言非常嚴格,而弱類型可以隨意使用。強類型語言在編譯時就會告訴你錯誤,而其它語言需要在運行時,才能知道錯誤。

舉個例子,我們將數(shù)值存儲在整型 / 符點型 / 雙精度符點型的變量中,并且與存儲在字符串中的變量進行比較時,有的語言會進行自動類型轉(zhuǎn)換,然后進行比較,而有的語言并不會。

結(jié)語

編程七宗罪,讓人不爽。我們需要避免出現(xiàn)。

這個僅僅是在編程中出現(xiàn)的常見錯誤。你很難看到,一個程序員,在他的程序中出現(xiàn)這些問題。但這也正如圣經(jīng)中的七宗罪一樣,不僅是這些問題。它們是原罪,可以組合成不同的錯誤。

你認為還有什么錯誤需要加在這個列表里面,在評論中寫出來,讓我知道。

Happy Coding!

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

    關(guān)注

    88

    文章

    3628

    瀏覽量

    93811
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4802

    瀏覽量

    68738
  • 數(shù)字化
    +關(guān)注

    關(guān)注

    8

    文章

    8779

    瀏覽量

    61899

原文標題:“編程不規(guī)范,同事兩行淚!”

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

收藏 人收藏

    評論

    相關(guān)推薦

    OSI層模型中各層的協(xié)議 OSI層模型的優(yōu)勢與不足

    OSI層模型中各層的協(xié)議 OSI(Open Systems Interconnection)層模型是一個用于描述網(wǎng)絡(luò)通信功能的分層模型。每一層都負責不同的功能和任務(wù),并定義了相應(yīng)的協(xié)議來支持這些
    的頭像 發(fā)表于 11-24 10:54 ?394次閱讀

    如何選擇適合自己的編程語言

    。 1. 確定目標和興趣 在選擇編程語言之前,首先要明確自己的目標和興趣。這包括你想要開發(fā)什么類型的項目,以及對哪些技術(shù)領(lǐng)域感興趣。例如,如果對網(wǎng)頁開發(fā)感興趣,那么學(xué)習(xí)HTML、CSS和JavaScript可能是一個不錯的選
    的頭像 發(fā)表于 11-15 09:37 ?436次閱讀

    比亞迪攜手申,進軍兩輪車市場探索鋰電替代鉛酸方案

    10月29日最新消息顯示,乘用車電池巨頭比亞迪正積極拓展兩輪車市場。據(jù)江蘇申車業(yè)有限公司10月28日上午發(fā)布的消息,江蘇申與比亞迪聯(lián)合成立的鋰電池包經(jīng)營顧問委員會已正式揭牌。
    的頭像 發(fā)表于 10-29 15:32 ?1450次閱讀

    單片機方案開發(fā)-分享個常用的外圍電路設(shè)計

    。掌握上述大常用外圍電路設(shè)計的精髓,不僅能夠幫助您在設(shè)計過程中少走彎路,更能為您的電子產(chǎn)品增添一份專業(yè)與可靠。希望本文能為您的電子設(shè)計之路提供有益的參考和啟發(fā)
    發(fā)表于 09-24 15:59

    【「倉頡編程快速上手」閱讀體驗】+壹讀后感

    感謝電子發(fā)燒友論壇提供的讀書機會,領(lǐng)略到華為公司開創(chuàng)的新語言:倉頡編程 。 在閱讀《倉頡編程快速上手》這本書后,我深受啟發(fā)。這本書猶如一把鑰匙,為那些渴望踏入編程世界的人打開了一扇便
    發(fā)表于 09-06 20:12

    工業(yè)機器人的四種編程(示教編程、離線編程、自增強現(xiàn)實編程編程)剖析!

    和工作量,提高編程效率,實現(xiàn)編程的自適應(yīng)性,從而提高生產(chǎn)效率,是機器人編程技術(shù)發(fā)展的終極追求。本文將就機器人編程技術(shù)的發(fā)展作一介紹,希望能給讀者帶來一些
    的頭像 發(fā)表于 08-30 12:14 ?2772次閱讀
    工業(yè)機器人的四種<b class='flag-5'>編程</b>(示教<b class='flag-5'>編程</b>、離線<b class='flag-5'>編程</b>、自增強現(xiàn)實<b class='flag-5'>編程</b>主<b class='flag-5'>編程</b>)剖析!

    段數(shù)碼管怎么判斷共陰共陽

    和控制方式上有所不同。 一、段數(shù)碼管的基本原理 段數(shù)碼管的組成 段數(shù)碼管由個發(fā)光二極管(LED)組成,分別標記為a、b、c、d、e、
    的頭像 發(fā)表于 08-28 16:17 ?1821次閱讀

    知道共模電感用錯了會有什么影響嗎

    電子發(fā)燒友網(wǎng)站提供《知道共模電感用錯了會有什么影響嗎.docx》資料免費下載
    發(fā)表于 07-30 10:42 ?0次下載

    esp8266 GPIO口會有電流泄露,如何避免?

    請教當esp8266 的EN口被外界拉低,芯片進入關(guān)閉狀態(tài),理論上GPIO口為高阻是嗎? 為什么我的電路當EN口為低時,插上usb給鋰電池充電,這時觸摸電路板,很容易就導(dǎo)致接在GPIO3上的LED微微亮起來(低電平亮)。 這時mcu并沒有啟動,為什么GPIO口會有電流
    發(fā)表于 07-08 07:48

    輸出共模電感為什么會有噪音

    電子發(fā)燒友網(wǎng)站提供《輸出共模電感為什么會有噪音.docx》資料免費下載
    發(fā)表于 07-04 17:06 ?1次下載

    市場上有類網(wǎng)線嗎

    類網(wǎng)線。類線(Category 7)是ISO/IEC 11801 7類/F級標準中最新的一種雙絞線,它主要為了適應(yīng)萬兆位以太網(wǎng)技術(shù)的應(yīng)用和發(fā)展。以下是關(guān)于類網(wǎng)線的詳細特點: 結(jié)構(gòu):
    的頭像 發(fā)表于 07-04 09:38 ?486次閱讀

    生成式AI的「七宗罪」!

    面對生成式AI日漸增長的「罪惡」,我們該如何解決問題?
    的頭像 發(fā)表于 05-07 16:34 ?1781次閱讀
    生成式AI的「<b class='flag-5'>七宗罪</b>」!

    電感質(zhì)量不好會有什么后果

    電子發(fā)燒友網(wǎng)站提供《電感質(zhì)量不好會有什么后果.docx》資料免費下載
    發(fā)表于 03-29 14:51 ?0次下載

    偉實業(yè)已與上市公司金信諾集團宣布達成PCB工廠投資協(xié)議

    據(jù)偉實業(yè)官微1月10報道,偉實業(yè)已與上市公司金信諾集團宣布達成PCB工廠投資協(xié)議,偉實業(yè)將分兩期投資,持有金信諾PCB工廠10%的股份,正式成為金信諾PCB工廠的重要股東。
    的頭像 發(fā)表于 01-13 15:45 ?1598次閱讀

    36張電氣控制三菱PLC梯形圖編程方法匯總

    PLC為例,介紹一下PLC梯形圖編程的方法,希望對大家有所幫助。
    的頭像 發(fā)表于 01-13 14:30 ?2779次閱讀
    36張電氣控制三菱PLC梯形圖<b class='flag-5'>編程</b>方法匯總