• <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>
            posts - 13, comments - 4, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            Exceptional C++ Style 讀書筆記(一)

            Posted on 2008-11-03 20:36 Batiliu 閱讀(481) 評論(0)  編輯 收藏 引用 所屬分類: 讀書筆記

            第一條 vector的使用

            設(shè)計vector是用來代替內(nèi)置數(shù)組的,因此其效率應(yīng)該與內(nèi)置數(shù)組一樣,內(nèi)置數(shù)組在下標(biāo)索引(operator[])時是不進(jìn)行越界檢查的。如果你需要下標(biāo)越界檢查,可以使用at方法。

             

            準(zhǔn)則記住size/resize以及capacity/reserve之間的區(qū)別。
            • size告訴你容器中目前實際有多少個元素,而對應(yīng)地,resize則會在容器的尾部添加或刪除一些元素。這兩個函數(shù)對list、vector、deque都適用,但對其他容器并不適用。
            • capacity則告訴你最少添加多少個元素才會導(dǎo)致容器重分配內(nèi)存,而reserve在必要的時候總是會使容器的內(nèi)部緩沖區(qū)擴(kuò)充至一個更大的容量,以確保至少能滿足你所指出的空間大小。這兩個函數(shù)僅對vector適用。

             

             

            準(zhǔn)則

            • 記得使用const_iterator。
            • 盡量使用!=而不是<來比較兩個iterator。
            • 養(yǎng)成默認(rèn)情況下使用前綴形式的--和++的習(xí)慣,除非你的確需要用到原來的值。
            • 盡量服用標(biāo)準(zhǔn)庫中已有的算法,例如for_each()。

             

             

            第二條 第三條 字符串格式化

                   sprintf     snprintf     stringstream     strstream     boost::lexical_cast    
            易用嗎,代碼清晰明確嗎
            高效嗎,無額外內(nèi)存分配嗎
            長度安全嗎
            類型安全嗎
            是否可以用于模板之中
                    是            是               否                    否                      是
                    是            是               否                    是                      否
                    否            是               是                    是                      是
                    否            否               是                    是                      是
                    否            否               是                    是                      是

             

            準(zhǔn)則

            • 如果你所要做的只是將一個值轉(zhuǎn)換為一個字符串的話,盡量默認(rèn)使用boost::lexical_cast。
            • 如果想進(jìn)行簡單的格式化,或者需要支持寬字符串,或者在模板當(dāng)中進(jìn)行格式化,盡量使用stringstream或strstream。
            • 如果想進(jìn)行一些復(fù)雜的格式化,停駛并不需要支持寬字符串,也不想讓代碼用在模板當(dāng)中的話,盡量使用snprintf。
            • 永遠(yuǎn)不要使用sprintf。

             

            第四條 標(biāo)準(zhǔn)庫成員函數(shù)

            使用標(biāo)準(zhǔn)庫里面的mem_fun,將成員函數(shù)適配為仿函數(shù)(functor),從而可被標(biāo)準(zhǔn)庫算法以及其他正常情況下只適用自由函數(shù)的代碼所使用。但不要將它用在標(biāo)準(zhǔn)庫自己身上。

             

            第五條 第六條 泛型性的風(fēng)味

             

            準(zhǔn)則如果你的類型有一個更好的途徑可以用于交換其對象的值的話,請考慮為它特化std::swap()。

             

            // 示例:重載swap()。
             
            class X {
            public:
                void swap(X&);
            };
             
            // 注意:這個重載并沒有放在std名字空間當(dāng)中。請參考名字空間Koenig查找。
            swap(X&a, X&b) {
                a.swap(b);
            }

             

            第七條 泛型性的風(fēng)味

             

            準(zhǔn)則記住,函數(shù)模板不能偏特化,只能重載。寫一個看似函數(shù)模板偏特化的函數(shù)模板實際上是在寫一個單獨的主函數(shù)模板。

             

             

            在如下代碼中,最后一行代碼調(diào)用的是f()的那個版本?

            // 示例:函數(shù)特化。
             
            template <typename T>    // (a):一個主模板
            void f(T);
             
            template <typename T>    // (b):一個主模板,重載了(a)
            void f(T*);
             
            template <>              // (c):(a)的一個顯示特化(全特化)
            void f<int*>(int*);
             
            template <>              // (d):(b)的一個顯示特化(全特化)
            void f<int>(int*);
             
            // ....
             
            int * p;
            f(p);                    // 調(diào)用的哪個版本?

            答案是……調(diào)用(d),想必結(jié)果是你意料之中。如果我們注釋掉(d),f()調(diào)用的又是哪個版本呢?答案是……調(diào)用(b),是不是讓你大吃一驚?如果這令你感到驚訝的話,你并不是唯一一個,當(dāng)時它曾讓許多專家大吃一驚。理解這個例子的關(guān)鍵其實很簡單:模板特化并不參加重載。

             

             

            準(zhǔn)則記住,函數(shù)模板特化并不參與重載決議。只有在某個主模板被重載決議選中的前提下,其特化版本才有可能被使用。而且,編譯器在選擇主模板的時候并不關(guān)心它是否有某個特化版本。

             

            讓我們來看看函數(shù)模板的重載規(guī)則。

            • 非模板函數(shù)是C++中的一等公民。如果一個普通的非模板函數(shù)跟一個函數(shù)模板在重載解析的參數(shù)匹配中表現(xiàn)一樣好的話,編譯器會選擇普通函數(shù)。
            • 如果編譯器沒有發(fā)現(xiàn)合適的一等公民,那么主函數(shù)模板作為C++中的二等公民就會被納入考慮。具體選擇哪個主函數(shù)模板則取決于哪個的參數(shù)類型匹配的最好。
            • 如果這個被選中的主函數(shù)模板碰巧有針對所使用的模板實參做了特化的話,該特化版本才會被編譯器選中。否則編譯器將使用以正確類型實例化的主模板。
            • 等等

             

             

            準(zhǔn)則如果你想要將一個主模板特化,同時又希望該特化版本能夠參與重載決議(或希望確保當(dāng)它完全匹配用戶調(diào)用時能被編譯器選中)的話,只需將其寫成普通函數(shù)即可。

            推論:如果你確實提供了某個函數(shù)模板的重載,那么你應(yīng)當(dāng)避免為它提供特化。

             

             

            準(zhǔn)則如果你正在寫一個可能需要被特化的主函數(shù)模板的話,請盡量將它寫成一個孤立的、永遠(yuǎn)不該被特化或重載的函數(shù)模板,并將其具體實現(xiàn)全部放入一個包含了一個靜態(tài)函數(shù)的類模板當(dāng)中。這么一來任何人都可以對后者進(jìn)行特化(全特化或偏特化),而同時又不會影響到主函數(shù)模板的重載決議。

             

            // 示例:函數(shù)特化。
             
            template <typename T>
            struct X;
             
            template <typename T>            // 請不要動這個函數(shù)
            void f(T t) { X<T>::far(t); }
             
            template <typename T>            // 可以對這個函數(shù)進(jìn)行特化
            struct X {
                static void f(T t);
            };

             

            第八條 友元模板

            準(zhǔn)則明確地表達(dá)出你的意圖。如果你所指的確實是一個模板,可以在模板名字后面加上模板實參列表(可以為空,即<>)。

             

            // 示例:友元模板。
             
            namespace boost {
                template <typename T> void checked_delete(T* x);
            }
             
            class Test {
                friend void boost::checked_delete<Test>(Test* x);    // 或"checked_delete<>(Test* x)"
            }

             

            第九條 第十條 導(dǎo)出限制

            準(zhǔn)則記住,export并不能帶來像普通函數(shù)那樣的真正的分離式編譯。

            準(zhǔn)則記住,export只能隱藏依賴性,并不能消除依賴性。

            準(zhǔn)則(就目前而言)避免使用export。

             

            第十一條 第十二條 異常安全問題

            準(zhǔn)則

            • 為應(yīng)用程序或子系統(tǒng)確立一個整體的錯誤報告/處理策略,并始終遵循它。并為錯誤報告、錯誤傳播以及錯誤處理制定策略。
            • 在那些偵測到錯誤而自身又無法對其進(jìn)行處理的地方拋出異常。
            • 在那些具備有足夠知識和上下文信息去處理/轉(zhuǎn)換錯誤或強(qiáng)制實施邊界條件的地方編寫try/catch(例如,在子系統(tǒng)邊界上或其他運(yùn)行時防火墻邊界上進(jìn)行catch(…))。

            準(zhǔn)則函數(shù)應(yīng)當(dāng)總是支持它所能支持的最強(qiáng)的異常安全保證,但前提是不能給那些并不需要該保證的調(diào)用者帶來額外開銷。

            準(zhǔn)則永遠(yuǎn)不要允許析構(gòu)函數(shù)、釋放操作以及swap()函數(shù)拋出任何異常,因為否則的話,就沒法安全且可靠地進(jìn)行資源清理了。

            準(zhǔn)則

            • 永遠(yuǎn)不要為函數(shù)加上異常規(guī)格。
            • 除非你想聲明的是空異常規(guī)格列表(即throw()),但仍不推薦這樣做。
            亚洲成色WWW久久网站| 久久婷婷国产剧情内射白浆| 国产亚洲精久久久久久无码77777| 久久精品综合一区二区三区| 久久久精品国产Sm最大网站| 久久精品亚洲男人的天堂| 精品久久久久久无码人妻蜜桃 | 婷婷综合久久狠狠色99h| 国产精品久久午夜夜伦鲁鲁| 久久99中文字幕久久| 人人狠狠综合久久亚洲| 久久丫精品国产亚洲av不卡 | 久久这里只有精品首页| 狠狠色婷婷久久一区二区| 2021久久精品国产99国产精品| 久久国产色AV免费看| 久久久久亚洲AV无码专区桃色 | 亚洲午夜精品久久久久久人妖| 岛国搬运www久久| 久久久噜噜噜久久中文字幕色伊伊 | 久久亚洲日韩精品一区二区三区| 久久精品亚洲精品国产色婷 | 亚洲国产一成久久精品国产成人综合| 一个色综合久久| 99久久这里只有精品| 香蕉久久久久久狠狠色| 亚洲国产精品久久久久网站| 久久久久久久久久久久久久| 久久99精品免费一区二区| 无码人妻久久一区二区三区| 欧美精品丝袜久久久中文字幕 | 亚洲国产精品人久久| 久久亚洲AV成人出白浆无码国产| 久久夜色精品国产www| 国产精品一久久香蕉国产线看| 伊人久久一区二区三区无码| 国产精品免费久久久久久久久| 久久99久久99精品免视看动漫| 国产毛片欧美毛片久久久| 亚洲第一永久AV网站久久精品男人的天堂AV| 99久久er这里只有精品18|