• <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>

            Exceptional C++ 讀書筆記2

            永遠不要用#include包含不必要的頭文件

            如果只需要流的前置聲明,應該優先使用#include<iosfwd>

            只需要前置聲明時,絕不要用#include包含相應的頭文件。

            如果使用聚合關系就已經足夠,就不要使用繼承。

            要避免使用內聯或者復雜的調整方法,除非通過性能分析證明這確實是必要的。

            正確使用名字空間。如果將一個類放入名字空間,那么同時要保證將這個類的所有輔助函數和運算符函數也放入相同的名字空間。否則,你將在代碼中發現奇怪的結果。
            要理解這五種不同類型的內存,了解他們為什么是不同的,以及他們各自的行為又是怎么樣:棧(自動變量)、自由存儲(new/delete)、堆(malloc/free)、全局(靜態變量、全局變量、文件作用域變量等)、常量數據(字符串常量等)。

            優先使用自由存儲(new/delete),避免使用堆(malloc/free)。

            對于“堆”和“自由存儲”進行區分,這一點很重要,因為在C++標準中有意避開了這兩種類型的內存是不是相關的這個問題。例如,當通過::operator delete()函數來釋放內存時,在C++標準的18.4.1.1中,最后一項是這樣的:
            “ 在C++標準中并沒有規定,在哪些情況下,在通過operator delete回收的存儲空間中,有一部分或者全部的控件可以再隨后調用operator new或者calloc,malloc以及realloc等函數時被重新分配,這些函數的聲明時在<cstdlib>中。”
            而且,在C++標準中也沒有規定,new/delete是否需要通過malloc/free來實現。不過,在C++標準20.4.6節的第3段和第4段中規定了,malloc/free一定不能使用new/delete來實現:“calloc、malloc和realloc函數不會通過調用::operator new()來分配存儲空間。函數free()不會通過調用::operator delete() 來釋放內存。”

            如果在類中定義了new和delete中的任意一個運算符函數,那么一定要同時定義另外一個。

            通常應該顯式地將函數operator new ()和operator delete()聲明為靜態函數。他們永遠都不能使非靜態成員函數。

            永遠都不要通過多態的方式處理數組。

            優先選擇使用vector或者deque,而不是數組。

            在編寫拷貝賦值運算符函數時,永遠都不要指望能夠通過對自我賦值進行檢測來保證函數的正確性;應該在拷貝賦值運算符函數中使用“創建臨時對象并進行交換”的慣用法,這種方法不僅是異常安全的,而且在處理自我賦值時也是安全的。

            可以將自我賦值檢測作為一種優化手段,以避免不必要的工作,這是正確地做法。

            不僅要避免編寫類型轉換運算符函數,而且還要避免編寫隱式的構造函數。

            盡量編寫異常安全的代碼。在編寫代碼時應該始終遵循:即使在出現異常時,資源仍然能夠被正確地釋放,并且數據也總是處于一致的狀態。

            避免使用語言中那些不常用的特性,而應該使用最簡單并且有效的技術。

            拷貝初始化過程絕不是賦值過程,因此在初始化中永遠都不會調用函數T::operator=()。是的,我知道在初始化語句中有一個“=”符合,但不要被它迷惑。它只是從C語言中沿用過來的一種語法,并不代表賦值運算。

            如果可能的話,優先使用“T t(u);”這種形式,而不是“T t=u;”的形式。通常,能能夠時候后者的地方,都可以使用前者,并且使用前者還有更多的好處——例如,可以帶多個參數。

            在函數聲明中,如果參數是以傳值方式來傳遞的,則不要使用const。而如果在這個函數的定義中,參數是不能被修改的,那么應該使用const。

            對于不是內置類型的返回值來說,當使用返回值的方式而不是返回引用的方式時,應該優先選擇返回const值。

            const 和mutable都是你的朋友

            優先使用新形式的類型轉換。

            不要通過類型轉換去掉常量屬性,而應該使用mutable。

            避免使用向下的類型轉換。

            優先通過引用方式來傳遞對象參數,而不是傳值方式,并且在所有可能的地方都使用const。

            避免使用內聯,除非從性能的分析上來看確實有必要這么做。

            避免使用全局變量或者靜態變量。如果必須使用,那么一定要特別注意這些變量的初始化順序。

            在構造函數的初始化列表中,應該把 基類按照他們在類定義中出現的先后順序進行排列。

            在編寫代碼時,永遠都不應該依賴函數參數的求值順序

            posted on 2014-08-22 15:00 Daywei 閱讀(1550) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            <2014年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章檔案

            牛人博客

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久成人精品| 久久精品国产亚洲av影院| 久久久久亚洲精品天堂久久久久久 | 一本色道久久99一综合| 久久精品欧美日韩精品| 久久99精品国产一区二区三区 | AV狠狠色丁香婷婷综合久久| 精品久久久久久综合日本| 亚洲&#228;v永久无码精品天堂久久| 国产精品99久久久久久宅男小说| 久久久久久久97| 欧美伊人久久大香线蕉综合 | 99久久99久久精品国产片| 久久人人爽人人爽人人片AV麻烦| 久久久久久久尹人综合网亚洲 | 久久精品国产免费观看| 国产精品一区二区久久精品无码 | 九九久久精品无码专区| 久久精品国产亚洲AV大全| 国产精品久久久久蜜芽| 国产精品九九久久免费视频 | 亚洲国产成人久久综合一区77| 久久人人爽人人爽人人片AV不| 亚洲精品乱码久久久久久蜜桃 | 久久久久久久波多野结衣高潮| 99久久国产综合精品网成人影院 | 91精品国产91久久久久久青草 | 久久99精品久久久久子伦| 久久人人爽人人爽人人片AV不 | 久久久精品视频免费观看| 88久久精品无码一区二区毛片| 久久99精品国产麻豆| 999久久久无码国产精品| 热re99久久精品国99热| 亚洲国产另类久久久精品黑人| 亚洲va久久久噜噜噜久久| 久久这里的只有是精品23| 久久中文字幕人妻丝袜| 一本一本久久aa综合精品| 亚洲国产另类久久久精品| 久久久久女人精品毛片|