成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何編寫可讀的代碼

開發 前端
在過去的五年里,我們收集了上百個“壞代碼”的例子(其中很大一部分是我們自己寫的),并且分析是什么原因使它們變壞,使用什么樣的原則和技術可以讓它們變好。

代碼最重要的讀者不再是編譯器、解釋器或者電腦,而是人。寫出的代碼能讓人易于理解、輕松維護、容易擴展的程序員才是專業的程序員。

編寫可讀的代碼

代碼應當易于理解

在過去的五年里,我們收集了上百個“壞代碼”的例子(其中很大一部分是我們自己寫的),并且分析是什么原因使它們變壞,使用什么樣的原則和技術可以讓它們變好。我們發現所有的原則都源自同一個主題思想。

關鍵思想:代碼應當易于理解

我們相信這是當你考慮要如何寫代碼時可以使用的最重要的指導原則。我們會展示如何把這條原則應用于你每天編碼工作的各個不同方面。但在開始之前,我們會詳細地介紹這條原則并證明它為什么這么重要。

是什么讓代碼變得“更好”

大多數程序員(包括兩位作者)依靠直覺和靈感來決定如何編程。我們都知道這樣的代碼:

  1. for (Node* node = list->head; node != NULL; nodenode = node->next)     
  2. Print (node->data); 

比下面的代碼好:

  1. Node* node = list->head;     
  2. if (node == NULL) return;     
  3. while (node->next != NULL) {     
  4. Print (node->data);     
  5. node = node->next;     
  6. }     
  7. if (node != NULL) Print (node->data); 

(盡管兩個例子的行為完全相同。)但很多時候這個選擇會更艱難。例如,這段代碼:

  1. return exponent >= 0 ? mantissa * (1 << exponent) : mantissa / (1 << -exponent);  

它比下面這段要好些還是差些?

  1. if (exponent >= 0) {  
  2. return mantissa * (1 << exponent);  
  3. else {     
  4. return mantissa / (1 << -exponent);     

第一個版本更緊湊,但第二個版本更直白。哪個標準更重要呢?一般情況下,在寫代碼時你如何來選擇?

可讀性基本定理

在對很多這樣的例子進行研究后,我們總結出,有一種對可讀性的度量比其他任何的度量都要重要。因為它是如此重要,我們把它叫做“可讀性基本定理”。

關鍵思想:代碼的寫法應當使別人理解它所需的時間最小化。

這是什么意思?其實很直接,如果你叫一個普通的同事過來,測算一下他通讀你的代碼并理解它所需的時間,這個“理解代碼時間”就是你要最小化的理論度量。

并且當我們說“理解”時,我們對這個詞有個很高的標準。如果有人真的完全理解了你的代碼,他就應該能改動它、找出缺陷并且明白它是如何與你代碼的其他部分交互的。

現在,你可能會想:“誰會關心是不是有人能理解它?我是唯一使用這段代碼的人!”就算你從事只有一個人的項目,這個目標也是值得的。那個“其他人”可能就是 6 個月的你自己,那時你自己的代碼看上去已經很陌生了。而且你永遠也不會知道——說不定別人會加入你的項目,或者你“丟棄的代碼”會在其他項目里重用。

總是越小越好嗎

一般來講,你解決問題所用的代碼越少就越好。很可能理解 2000 行代碼寫成的類所需的時間比 5000 行的類要短。但少的代碼并不總是更好!很多時候,像下面這樣的一行表達式:

  1. assert ((!(bucket = FindBucket (key))) !bucket->IsOccupied ()); 

理解起來要比兩行代碼花更多時間:

  1. bucket = FindBucket (key);     
  2. if (bucket != NULL) assert (!bucket->IsOccupied ()); 

類似地,一條注釋可以讓你更快地理解代碼,盡管它給代碼增加了長度:

  1. // Fast version of “hash = (65599 * hash) + c”     
  2. hash = (hash << 6) + (hash << 16) – hash + c; 

因此盡管減少代碼行數是一個好目標,但把理解代碼所需的時間最小化是一個更好的目標。

理解代碼所需的時間是否與其他目標有沖突

你可能在想:“那么其他約束呢?像是使代碼更有效率,或者有好的架構,或者容易測試等?這些不會在有些時候與使代碼容易理解這個目標沖突嗎?”我們發現這些其他目標根本就不會互相影響。就算是在需要高度優化代碼的領域,還是有辦法能讓代碼同時可讀性更高。并且讓你的代碼容易理解往往會把它引向好的架構且容易測試。有些程序員對于任何沒有完美地分解的代碼都不自覺地想要修正它。這時很重要的是要停下來并且想一下:“這段代碼容易理解嗎?”如果容易,可能轉而關注其他代碼是沒有問題的。

最難的部分

是的,要經常地想一想其他人是不是會覺得你的代碼容易理解,這需要額外的時間。這樣做就需要你打開大腦中從前在編碼時可能沒有打開的那部分功能。但如果你接受了這個目標(像我們一樣),我們可以肯定你會成為一個更好的程序員,會產生更少的缺陷,從工作中獲得更多的自豪,并且編寫出你周圍人都愛用的代碼。

本文節選自《編寫可讀代碼的藝術》一書,Dustin Boswell、Trevor Foucher 著,尹哲、鄭秀雯譯,由機械工業出版社出版。

原文鏈接:http://blog.jobbole.com/23599/

【編輯推薦】

  1. 再議頁面前端的水有多深
  2. Web前端:11個讓你代碼整潔的原則
  3. 寫更少的代碼
  4. 復制粘貼代碼真的有問題嗎?
  5. 前端工程師的價值體現在哪里?
責任編輯:張偉 來源: 伯樂在線
相關推薦

2013-03-22 16:43:03

可讀代碼代碼的藝術代碼編寫

2024-04-23 08:01:20

面向對象C 語言代碼

2011-04-15 15:16:18

代碼編程

2015-08-27 13:11:18

JavaScript代碼

2021-10-09 10:24:53

Java 代碼可讀性

2021-03-17 08:00:59

JS語言Javascript

2022-06-07 09:30:35

JavaScript變量名參數

2024-06-24 14:19:48

2014-04-25 09:02:17

LuaLua優化Lua代碼

2013-04-15 09:02:43

JavaScriptJS

2024-03-20 08:00:00

軟件開發Java編程語言

2023-10-10 08:00:00

2010-02-05 16:49:05

編寫Android 代

2012-03-15 13:36:51

云計算JavaSpring框架

2015-01-28 14:30:31

android代碼

2022-06-27 06:23:23

代碼編程

2021-06-08 09:35:11

Cleaner ReaReact開發React代碼

2022-12-15 10:52:26

代碼開發

2009-02-01 14:34:26

PythonUnix管道風格

2011-03-24 13:09:11

數據庫代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: dy天堂| 国产超碰人人爽人人做人人爱 | 国产亚洲一区二区在线观看 | 高清视频一区二区三区 | 亚洲精品一区二区三区在线 | 欧美视频二区 | 91亚洲精品在线观看 | 国产精品亚洲综合 | 黄色一级大片在线观看 | 日韩α片 | 亚洲精品日韩在线 | 日本涩涩视频 | 国产成人高清视频 | 欧美不卡网站 | 久草99 | 精品国产乱码久久久久久丨区2区 | 亚洲成av片人久久久 | 91新视频 | 操视频网站 | 国产农村妇女毛片精品久久麻豆 | 91成人| 成人亚洲片 | 欧美日韩高清 | 亚洲精品乱码 | 欧美精品欧美精品系列 | 国产一区二区三区四区 | 欧美三级免费观看 | 一区二区久久 | 国产精品99久久久精品免费观看 | 亚洲国产欧美在线人成 | 国产激情福利 | 成人精品在线观看 | 蜜臀久久99精品久久久久久宅男 | 欧美激情区 | 国产乱人伦 | 中文字幕成人在线 | 久久久青草婷婷精品综合日韩 | 羞羞视频在线观看网站 | 久久久久综合 | 在线视频成人 | 极品粉嫩国产48尤物在线播放 |