<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    tbwshc

    提高代碼可讀性的十大注釋技巧

    很多程序員在寫代碼的時(shí)候往往都不注意代碼的可讀性,讓別人在閱讀代碼時(shí)花費(fèi)更多的時(shí)間。其實(shí),只要程序員在寫代碼的時(shí)候,注意為代碼加注釋,并以合理的格式為代碼加注釋,這樣就方便別人查看代碼,也方便自己以后查看了。下面分享十個(gè)加注釋的技巧:

    1. 逐層注釋

    為每個(gè)代碼塊添加注釋,并在每一層使用統(tǒng)一的注釋方法和風(fēng)格。例如:

    針對(duì)每個(gè)類:包括摘要信息、作者信息、以及最近修改日期等;

    針對(duì)每個(gè)方法:包括用途、功能、參數(shù)和返回值等。

    在團(tuán)隊(duì)工作中,采用標(biāo)準(zhǔn)化的注釋尤為重要。當(dāng)然,使用注釋規(guī)范和工具(例如C#里的XML,Java里的Javadoc)可以tb更好的推動(dòng)注釋工作完成得更好。

    2. 使用分段注釋

    如果有多個(gè)代碼塊,而每個(gè)代碼塊完成一個(gè)單一任務(wù),則在每個(gè)代碼塊前添加一個(gè)注釋來向讀者說明這段代碼的功能。例子如下:

    // Check that all data records
    // are correct
    foreach (Record record in records)
    ...{
    if (rec.checkStatus()==Status.OK)
    ...{
    . . .
    }
    }
    // Now we begin to perform
    // transactions
    Context ctx = new ApplicationContext();
    ctx.BeginTransaction();
    . . .

    3. 在代碼行后添加注釋

    如果多行代碼的每行都要添加注釋,則在每行代碼后添加該行的注釋,這將很容易理解。例如:

    const MAX_ITEMS = 10; // maximum number of packets
    const MASK = 0x1F;    // mask bit TCP
    在分隔代碼和注釋時(shí),有的開發(fā)者使用tab鍵,而另一些則使用空格鍵。然而由于tab鍵在各編輯器和IDE工具之間的表現(xiàn)不一致,因此最好的方法還是使用空格鍵。

    4. 不要侮辱讀者的智慧

    避免以下顯而易見的注釋:寫這些無(wú)用的注釋會(huì)浪費(fèi)你的時(shí)間,并將轉(zhuǎn)移讀者對(duì)該代碼細(xì)節(jié)的理解。

    if (a == 5)      // if a equals 5
    counter = 0; // set the counter to zero

    5. 禮貌點(diǎn)

    避免粗魯?shù)淖⑨專纾?#8220;注意,愚蠢的使用者才會(huì)輸入一個(gè)負(fù)數(shù)”或“剛修復(fù)的這個(gè)問題出于最初的無(wú)能開發(fā)者之手”。這樣的注釋能夠反映到它的作者是多么的拙劣,你也永遠(yuǎn)不知道誰(shuí)將會(huì)閱讀這些注釋,可能是:你的老板,客戶,或者是你剛才侮辱過的無(wú)能開發(fā)者。

    6. 關(guān)注要點(diǎn)

    不要寫過多的需要轉(zhuǎn)意且不易理解的注釋。避免ASCII藝術(shù),搞笑,詩(shī)情畫意,hyperverbosity的注釋。簡(jiǎn)而言之,保持注釋簡(jiǎn)單直接。

    7. 使用一致的注釋風(fēng)格

    一些人堅(jiān)信注釋應(yīng)該寫到能被非編程者理解的程度。而其他的人則認(rèn)為注釋只要能被開發(fā)人員理解就行了。無(wú)論如何,Successful Strategies for Commenting Code已經(jīng)規(guī)定和闡述了注釋的一致性和針對(duì)的讀者。就個(gè)人而言,我懷疑大部分非編程人員將會(huì)去閱讀代碼,因此注釋應(yīng)該是針對(duì)其他的開發(fā)者而言。

    8. 使用特有的標(biāo)簽

    在一個(gè)團(tuán)隊(duì)工作中工作時(shí),為了便于與其它程序員溝通,應(yīng)該采用一致的標(biāo)簽集進(jìn)行注釋。例如,在很多團(tuán)隊(duì)中用TODO標(biāo)簽表示該代碼段還需要額外的工作。

    int Estimate(int x, int y)
    ...{
    // TODO: implement the calculations
    return 0;
    }
    注釋標(biāo)簽切忌不要用于解釋代碼,它只是引起注意或傳遞信息。如果你使用這個(gè)技巧,記得追蹤并確認(rèn)這些信息所表示的是什么。

    9. 在代碼時(shí)添加注釋

    在寫代碼時(shí)就添加注釋,這時(shí)在你腦海里的是清晰完整的思路。如果在代碼最后再添加同樣注釋,它將多花費(fèi)你一倍的時(shí)間。而“我沒有時(shí)間寫注釋”,“我很忙”和“項(xiàng)目已經(jīng)延期了”這都是不愿寫注釋而找的借口。一些開發(fā)者覺得應(yīng)該write comments before code,用于理清頭緒。例如:

    public void ProcessOrder()
    ...{
    // Make sure the products are available
    // Check that the customer is valid
    // Send the order to the store
    // Generate bill
    }

    10. 為自己注釋代碼

    當(dāng)注釋代碼時(shí),要考慮到不僅將來維護(hù)你代碼的開發(fā)人員要看,而且你自己也可能要看。用Phil Haack大師的話來說就是:“一旦一行代碼顯示屏幕上,你也就成了這段代碼的維護(hù)者”。因此,對(duì)于我們寫得好(差)的注釋而言,我們將是第一個(gè)受益者(受害者)。

    posted on 2012-08-16 14:50 chen11-1 閱讀(1759) 評(píng)論(2)  編輯  收藏


    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 91精品国产亚洲爽啪在线影院| 国内精自视频品线六区免费| 国产美女被遭强高潮免费网站 | 国产成人免费永久播放视频平台| 亚洲精品视频在线| 国产一区二区免费| 亚洲精品无码久久久影院相关影片 | 国产青草亚洲香蕉精品久久| 成全影视免费观看大全二| 亚洲日韩精品无码专区加勒比☆| 免费看国产成年无码AV片| 亚洲最大的黄色网| 国产性生交xxxxx免费| 视频免费1区二区三区| 国产亚洲欧洲Aⅴ综合一区 | 永久在线观看www免费视频| 亚洲伊人久久大香线蕉| 色播在线永久免费视频| 成年大片免费高清在线看黄| 久久亚洲高清观看| 日本zzzzwww大片免费| 亚洲男人的天堂网站| 亚洲国产综合精品一区在线播放| 中国性猛交xxxxx免费看| 亚洲狠狠综合久久| 久久电影网午夜鲁丝片免费| 四虎影视久久久免费| 亚洲AV美女一区二区三区| 性短视频在线观看免费不卡流畅 | 亚洲日本va一区二区三区| 亚洲国产小视频精品久久久三级 | 亚洲午夜久久久久久噜噜噜| 亚洲黄色免费电影| 国产成人亚洲毛片| 久久亚洲日韩精品一区二区三区| 曰批全过程免费视频在线观看| 免费的黄色的网站| 亚洲系列中文字幕| 免费播放春色aⅴ视频| 一区二区在线免费观看| 国产精品亚洲色婷婷99久久精品|