青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

向往的程序人生

C,C++,設(shè)計模式,3D圖形學(xué),游戲開發(fā)
posts - 4, comments - 13, trackbacks - 0, articles - 0

C++編程中的一些感悟

Posted on 2009-04-23 15:44 向往 閱讀(1139) 評論(4)  編輯 收藏 引用 所屬分類: C/C++/Script
接觸C++已經(jīng)有五個年頭了,多多少少在學(xué)習(xí)和工作的過程中有些感悟,遂一一記錄,勉己勉人.
有少許字段是摘抄自網(wǎng)上的文章,但存檔時只是隨手黏貼,丟失了作者信息,無法列出,對此表示歉意,并感謝發(fā)揚分享精神的原作者.
此外,若以后有新的感悟?qū)⒃诖颂砑?有不當(dāng)之處,懇請指正.
  1. 指針賦值時,要謹(jǐn)防指針的同值性.如:
     1 void SharePtr::operator = (Ptr *ptr)
     2 {
     3     if(mPtr != ptr)        // 防止指針同值.其中mPtr是SharePtr類中用來保存指針的變 量.
     4     {
     5         if(mPtr != NULL)
     6         {
     7             delete mPtr;   // 如果不是同值, 刪除之前的指針.
     8             mPtr = ptr;
     9         }
    10     }
    11 

  2. 不要忽視編譯警告,有些警告是出現(xiàn)bug并導(dǎo)致程序crash的征兆。比如類型轉(zhuǎn)化警告、數(shù)據(jù)未初始化警告都可能導(dǎo)致程序出錯。為了以后減少調(diào)試和避免錯誤的幾率,請重視編譯器的警告信息。
  3. 當(dāng)工程需要給Class加導(dǎo)出前綴(如:__declspec(dllexport))卻有些沒有加時,其他工程引用它將會出現(xiàn) Unrezosle Symbol的錯誤.
  4. 若某個類需要作為父類,其析構(gòu)函數(shù)必須聲明為virtual,否正子類的析構(gòu)函數(shù)無法調(diào)用,導(dǎo)致內(nèi)存泄漏.
  5. 新增一個Class時,先定好接口,然后再編碼.這樣可以不用經(jīng)常改動,減少編譯時間. 
  6. 要謹(jǐn)防數(shù)值越界.對于有些存儲范圍小的變量,必須先進行越界處理,然后再賦值.如:
    // 未添加數(shù)據(jù)越界檢測代碼
    int num = -1;
    unsigned 
    char ch = num; // ch的值不是-1,而是255.因為num超出了unsigned char表示的范 圍.

    // 添加了數(shù)據(jù)越界檢測代碼
    int num = -1;
    assert(num 
    >=0 && num <= std::limit<unsinged char>::max());  // 若越界則彈出斷言
    unsigned char ch = num;
  7. 在宏里邊盡量不定義變量,否則在外部調(diào)用兩次時,有可能出現(xiàn)變量重復(fù)定義的錯誤.
    如果確實要定義變量,可以改寫成函數(shù).
  8. 不要為模式而模式.使用設(shè)計模式只是為了更好地復(fù)用和擴展,如果得到反作用,寧愿不用.
  9. 有些子類應(yīng)當(dāng)覆蓋抽象類vitual成員時,千萬不能誤寫為重載.否則很難查出錯誤.
  10. 若有兩個人做同一個模塊時,需要商量好整體架構(gòu),明確分工,不可隨意修改他人的代碼,若要修改也應(yīng)告訴原作者.若對某些分工意見有分歧時,應(yīng)慢慢磨合,耐心心細比較,確定可行方案,切不可逃避,將問題延續(xù)下去. 
  11. 定義接口時,盡量為使用者(用戶)提供明朗,統(tǒng)一,清晰的接口:
    1) 盡可能使用默認(rèn)參數(shù);
    2) 使用管理器管理物體的創(chuàng)建刪除;
    3) 使用抽象類抽象出若干類似Object的接口;
    4) 函數(shù)名盡量使用動詞或動賓結(jié)構(gòu),并體現(xiàn)出職責(zé);
    5) 在實現(xiàn)相同功能的情況下,對外提供的函數(shù)應(yīng)盡可能少;
    6) 能聲明成private或protected的數(shù)據(jù)成員和成員函數(shù)就不要聲明為public. 
  12. 每個對象應(yīng)當(dāng)完成并且只完成它該做的事,只管它該管的事,簡而言之,就是對象內(nèi)部,對象之間應(yīng)該保持"高內(nèi)聚,低耦合".
  13. 寫一個循環(huán)時,如果該循環(huán)體比較大,則應(yīng)該先寫好循環(huán)判斷條件,再實現(xiàn)細節(jié).
    while(i > 0)
    {
        
    --i;
    }
    //實現(xiàn)如上代碼后,再寫實現(xiàn)細節(jié)(循環(huán)體).這樣做的目的是可以避免在實現(xiàn)細節(jié)后忘記增加--i等這類循環(huán)因子更新語句.
    如:while(i > 0)
    {
        循環(huán) 體;
        
    --i;
    }
  14. 代碼中的注釋應(yīng)當(dāng)致力于解釋為什么,而不是怎么做。好的注釋并不是重復(fù)代碼中顯而易見的事實,而是引起對代碼中微妙的弱點的重 視。明白的代碼常常是被注釋所玷污了,不過對于作者顯而易見的東西對于讀者來說常常是晦澀的。一整段的注釋要比逐行解釋好的多。
  15. 類的組織Class organization
    1).按照以下順序組織類的定義,按照用戶最為關(guān)心的順序組織類的代碼:
    Public type forward-declarations & typedefs  
    Public constructors & destructor  
    Public member functions
    -----------------------------------------------------------
    Protected type forward-declarations & typedefs  
    Protected member functions  
    -----------------------------------------------------------
    Private type forward-declarations  
    Private member functions  
    Private data members  
    2).盡量不要在類的定義體中進行函數(shù)定義。模板及內(nèi)聯(lián)函數(shù)除外。
    3).復(fù)用public private protected關(guān)鍵字,將不同類型的成員分開,如成員函數(shù)和數(shù)據(jù)成員。
    4).在繼承類里就不要重復(fù)寫virtual關(guān)鍵字,可以 將它們的聲明組織成一組。
  16. 在使用new/delete, malloc/free時,注意"誰創(chuàng)建誰銷毀"的原則.除非有明確的規(guī)約,否則很容易造成內(nèi)存管理混亂,導(dǎo)致出現(xiàn)內(nèi)存錯誤.
  17. 頭文件包含其實是一想很煩瑣的工作,不但我們看著累,編譯器編譯的時候也很累,再加上頭文件中常常出現(xiàn)的宏定義。感覺各種宏定 義的展開是非常耗時間的,遠不如自定義函數(shù)來得速度。我僅就不同頭文件、源文件間的句則結(jié)構(gòu)問題提出兩點原則,僅供參考:
    第一個原則 應(yīng)該是,如果可以不包含頭文件,那就不要包含了。這時候前置聲明可以解決問題。如果使用的僅僅是一個類的指針,沒有使用這個類的具體對象(非指針),也沒 有訪問到類的具體成員,那么前置聲明就可以了。因為指針這一數(shù)據(jù)類型的大小是特定的,編譯器可以獲知。
    第二個原則應(yīng)該是,盡量在 CPP文件中包含頭文件,而非在頭文件中。假設(shè)類A的一個成員是是一個指向類B的指針,在類A的頭文件中使用了類B的前置聲明并便宜成功,那么在A的實現(xiàn) 中我們需要訪問B的具體成員,因此需要包含頭文件,那么我們應(yīng)該在類A的實現(xiàn)部分(CPP文件)包含類B的頭文件而非聲明部分(H文件)。
  18. 解決頭文件相互包含問題的方法之一:在.h文件里用class A聲明,數(shù)據(jù)成員用指針或者引用,在.cpp里用#include"A.h"即可.
  19. 在索引列表時,最好能根據(jù)索引和名字來獲取元素,以滿足不同場合的需求.在編輯器制作中更彰顯其意義.
  20. 在類A的構(gòu)造函數(shù)里如果有類B成員變量b,并調(diào)用了b的某個函數(shù)如b.fun(),則b.fun()里邊不能調(diào)用A的指針.因 為此時A的指針尚未完成空間分配,強行調(diào)用將導(dǎo)致出錯.
    這種情況在Debug下偶爾出錯,但在Release版下一定出錯.應(yīng)當(dāng)引起 重視!
  21. 以二進制存儲信息時,要注意int等類型在不同的平臺不同CPU架構(gòu)下長度是不一樣的,故在寫入文件時,建議先用宏 (如#define INT_LENGTH 4)來表示寫進文件的長度.此外,還要注意字節(jié)序(高位在前還是低位在前)的問題.
    所以一般情況下,用文本文件來存儲相關(guān)信息,避免 了那些問題.
  22. 由于std::vector里邊的內(nèi)存管理機制會適時釋放內(nèi)存以調(diào)整合適的大小,故在外部不要保存std::vector里的 元素地址.如果確實要保存,則每次增刪vector元素時必須更新外部的指針,否則將可能造成垃圾指針而出現(xiàn)內(nèi)存錯誤(有時候甚至不報錯,程序運行出現(xiàn)不 可預(yù)料的結(jié)果.很詭異,很難發(fā)現(xiàn)bug).
  23. 永遠不要在類的構(gòu)造或者析構(gòu)過程中調(diào)用虛函數(shù),因為這樣的調(diào)用永遠不會沿類繼承樹往下傳遞到子類中去。否則很有可能出現(xiàn)很隱晦 的bug.參見:http://www.enet.com.cn/article/2005/0706/A20050706431501_2.shtml
  24. 給有虛函數(shù)的模板類添加父類.即將公用接口抽象在父類里,就可以統(tǒng)一處理模板類了.

Feedback

# re: C++編程中的一些感悟  回復(fù)  更多評論   

2009-04-23 18:22 by Sunshine Alike
好文!學(xué)習(xí)了~~

# re: C++編程中的一些感悟  回復(fù)  更多評論   

2009-04-24 01:31 by sisco
感覺像大雜燴,不過有些條目精辟入里.謝謝!

# re: C++編程中的一些感悟  回復(fù)  更多評論   

2009-04-24 11:28 by 向往
@Sunshine Alike
@sisco
如果本文對大家有所幫助,是我寫文章的初衷和動力.謝謝賞閱.

# re: C++編程中的一些感悟  回復(fù)  更多評論   

2009-08-21 22:43 by 李現(xiàn)民
第六條,比較好

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一本色道久久综合精品竹菊| 亚洲欧美日韩成人| 久久成人综合视频| 99在线精品视频在线观看| 亚洲一区二区三区中文字幕| 亚洲成人在线| 亚洲人成网站777色婷婷| 欧美日韩国产经典色站一区二区三区| aa日韩免费精品视频一| 欧美激情一区二区三区全黄| 久久久久这里只有精品| 女女同性女同一区二区三区91| 欧美资源在线| 欧美国产成人在线| 亚洲第一在线| 亚洲理论在线| 欧美国产综合视频| 先锋影音久久| 久久成人久久爱| 国产精品入口夜色视频大尺度| 嫩草国产精品入口| 亚洲风情在线资源站| 亚洲欧美日韩专区| 国内久久婷婷综合| 午夜精品av| 久久嫩草精品久久久久| 亚洲已满18点击进入久久| 国产午夜精品全部视频在线播放| 亚洲美女性视频| 久久精品中文| 夜夜嗨av色一区二区不卡| 久久午夜羞羞影院免费观看| 久久久久久亚洲精品杨幂换脸| 亚洲国产日韩欧美| 欧美三级中文字幕在线观看| 亚洲欧美精品在线| 亚洲精品综合精品自拍| 国产精品99久久99久久久二8| 亚洲大片免费看| 亚洲淫片在线视频| 国产日韩精品久久| 女人香蕉久久**毛片精品| 美女尤物久久精品| 久久精品电影| 亚洲麻豆av| 欧美一区二区三区四区在线观看地址 | 麻豆av一区二区三区| 亚洲国产欧美不卡在线观看| 亚洲欧美日韩国产另类专区| 国产无遮挡一区二区三区毛片日本| 亚洲性人人天天夜夜摸| 亚洲国产欧美一区| 亚洲国产精品久久| 麻豆久久久9性大片| 午夜精品久久久久| 亚洲欧美日韩综合| 久久国产精品一区二区| 亚洲日本欧美天堂| 欧美午夜精品电影| 久久久久女教师免费一区| 久久国产66| 亚洲精品1234| 欧美激情精品久久久久久蜜臀 | 老牛嫩草一区二区三区日本| 亚洲美女福利视频网站| 国产精品日韩欧美一区二区三区 | 久久全国免费视频| 亚洲中字在线| 亚洲精品资源美女情侣酒店| 亚洲第一视频网站| 午夜久久电影网| 亚洲色图自拍| 久久久久综合网| 亚洲第一精品电影| 国产精品盗摄久久久| 国产精品日韩专区| 亚洲丁香婷深爱综合| 欧美日韩国产专区| 国产亚洲精品激情久久| 亚洲主播在线| 99精品欧美一区二区三区| 久久婷婷丁香| 99精品国产在热久久| 老司机午夜精品视频| 国产精品亚洲一区| 小处雏高清一区二区三区| 在线中文字幕一区| 欧美天堂亚洲电影院在线播放| 亚洲精品国产无天堂网2021| 亚洲国产精品精华液2区45| 久久人人97超碰国产公开结果 | 正在播放亚洲一区| 国产精品乱人伦中文| 欧美日韩在线一区二区| 伊人精品视频| 久久久久久夜精品精品免费| 午夜精品福利一区二区蜜股av| 另类人畜视频在线| 亚洲视频自拍偷拍| 亚洲一区二区日本| 欧美国产大片| 亚洲欧美春色| 久久婷婷国产综合尤物精品 | 亚洲欧美在线播放| 亚洲二区视频| 欧美一区二区三区成人| 亚洲国产婷婷| 国产日韩精品一区二区浪潮av| 另类激情亚洲| 国产精品一区在线观看你懂的| 久久精品国产69国产精品亚洲| 亚洲国产精品国自产拍av秋霞| 欧美精品色网| 亚洲第一天堂无码专区| 国产日韩欧美日韩| 99re亚洲国产精品| 日韩网站在线| 欧美日韩一区二区三区免费| 欧美/亚洲一区| 韩国一区二区三区在线观看| 亚洲欧美日韩国产| 亚洲一区二区黄色| 国产麻豆日韩欧美久久| 亚洲自拍另类| 久久久天天操| 在线国产日韩| 欧美激情一区在线观看| 这里只有视频精品| 欧美日韩在线观看一区二区| 欧美福利视频在线| 韩国视频理论视频久久| 翔田千里一区二区| 久久免费高清| 亚洲精品视频免费观看| 免费av成人在线| 亚洲精品国精品久久99热| 亚洲五月婷婷| 亚洲第一在线综合网站| 欧美ed2k| 久久免费视频一区| 一区二区三区欧美日韩| 欧美a级片一区| 久久精品亚洲一区二区| 日韩系列欧美系列| 久久精品一区| 亚洲一区二区在线免费观看| 怡红院精品视频在线观看极品| 麻豆精品91| 久久9热精品视频| 午夜国产欧美理论在线播放| 欧美在线免费一级片| 亚洲国产精品欧美一二99| 国产精品sm| 欧美日韩精品在线播放| 亚洲综合日韩中文字幕v在线| 亚欧美中日韩视频| 亚洲视频精选| 亚洲一区亚洲二区| 中日韩高清电影网| 亚洲视频电影图片偷拍一区| 亚洲第一中文字幕| 老司机成人在线视频| 亚洲精品自在在线观看| 99精品国产高清一区二区| 99精品欧美一区二区蜜桃免费| 久久久久综合网| 久久九九有精品国产23| 久久综合久久综合久久综合| 亚洲色图在线视频| 亚洲午夜一区二区三区| 亚洲欧美激情四射在线日| 亚洲激情六月丁香| 亚洲第一在线| 亚洲天堂激情| 99国产精品视频免费观看| 亚洲最新在线| 欧美怡红院视频一区二区三区| 久久久国产午夜精品| 欧美刺激午夜性久久久久久久| 欧美精品免费看| 国产欧美一区二区三区国产幕精品| 国产精品亚洲人在线观看| 亚洲国产精品久久人人爱蜜臀| 在线欧美亚洲| 亚洲欧美一区二区三区久久| 欧美一二三区在线观看| 亚洲国产高潮在线观看| 欧美一区二区三区免费看| 另类亚洲自拍| 国产九色精品成人porny| 亚洲美女电影在线| 久久久噜噜噜久噜久久| 亚洲美女中文字幕| 免费试看一区| 99综合电影在线视频| 欧美 日韩 国产精品免费观看| 欧美在线观看网址综合| 欧美亚一区二区| 亚洲影视在线| 亚洲一区二区毛片|