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

            歸去來兮

             

            effectiv c++ 讀書筆記之一

            開始寫effective c++的讀書筆記。今天是條款2:盡量以const,enum,inline替換#define(prefer consts,enums,and inlines to #define.)
            現在在維護代碼的時候,前輩們大片大片的宏搞得我是那個暈頭轉向啊,真希望他們也看過本條款。
            1.Case:#define ASPECT_RATIO 1.653
               Recommendation:const double AspectRatio = 1.653;
            Reason:   當使用ASPECT_RATIO但是獲得一個編譯錯誤信息時,可能你會很是發冏,因為這個錯誤信息也許會提到1.653而不是ASPECT_RATIO。如果ASPECT_RATIO定義在非你所寫的頭文件中,你更是因為追蹤他而浪費時間。改為推薦的方式后,你找到的肯定是AspectRatio。當以常量替換#define時,有兩種注意的情況,第一種是定義常量指針(const pointers)。由于常量定義式常放在頭文件內,因此有必要將指針也聲明為const。例如在一個頭文件內定義一個常量的char*-based字符串,必須寫const兩次:
            const char* const authorName = "Edmund";
            這里采用string對象比其前輩char*-based更合適,
            const std::string authorName("Edmund");
            第二種是class專屬常量。為了將常量的作用域限制在class內,你必須讓他成為class的一個成員;而為確保此常量只有一個實體,則必須聲明為static:
            class GamePlayer{
            private:
            static const int NumTurns = 5;
            int scores[NumTurns];
            ...
            }
            然而,你看到的是NumTurns的聲明式而不是定義式,C++通常要求我們所使用的任何東西都要有一個定義式,但如果他是個class的專屬常量而又是static且為整數類型(ints,chars,bools),則做特殊處理。只要不取他們的地址,你可以聲明并使用他們而無需提供定義式。但如果取某個class專屬常量的地址,或縱使不取地址而編譯器卻堅持要看到一個定義式,你就必須提供另外一個定義式:
            const int GamePlayer::NumTurns;
            由于NumTurns在聲明時已經獲得了初值,因此定義時不可以再設初值。此外,對所謂的“in-class初值設定”也只允許對整數常量進行。如果為非整型則可以采用下面的這種方式:
            class CostEstimate{
            private:
            static const double FudgeFactor;
            ...
            }

            const double CostEstimate::FudgeFactor = 1.35;
            當你在編譯期需要一個class常量值,例如在上述GamePlayer::scores的數組聲明中,此時如果編譯器不允許“static整數型class常量”完成“in-class初值設定”,可采用enum來解決,其理論基礎是“一個屬于枚舉類型的數值可權充ints被使用”,于是GamePlayer可定義如下:
            class GamePlayer{
            private:
            enum{NumTurns = 5};
            int scores[NumTurns];
            ...
            };
            注意:取一個const的值是合法的,但是取一個enum的值就是不合法的,取一個#define的值也是不合法的。如果你不想讓別人獲得一個pointer或者reference指向你的某個整數常量,enum可以幫助你實現這個約束。
            下邊繼續說預處理器。另外一個常見的#define誤用的情景是以他來實現宏,宏看起來像函數,但是不會招致函數調用帶來的額外開銷,例如:
            #define CALL_WITH_MAX(a,b) f((a)>(b)?(a):(b))。他的缺點就不說了,替代方式:
            template<class T> inline void callWithMax(const T& a, const T& b)
            {
            f(a > b?a : b);
            }
            本條目總結:
            1.對于單純常量,最好以const對象或者enums替換#defines;
            2.對于形似函數的宏,最好改用inline函數替換#defines。




            Ps:本文是第一次在cppblog上發表的文章,呵呵。很早就想在這上面寫點了,但是不是忙這就是忙那,昨天下定決心,先把effective C++(3e)里面的55條讀書筆記寫在這上面。打算每天一個條目,這里面好多跟書上的句子一樣,但是全是我自己敲進去的,不存在任何的paste。所寫均是自己搞清楚的,不明白地方的暫時沒有添加。

            posted on 2008-12-08 23:50 Edmund 閱讀(276) 評論(0)  編輯 收藏 引用

            導航

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            97精品国产97久久久久久免费| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久天天躁狠狠躁夜夜网站| 久久精品麻豆日日躁夜夜躁| 99久久国产免费福利| 性高朝久久久久久久久久| 久久99热这里只频精品6| 久久大香香蕉国产| 久久影院久久香蕉国产线看观看| 一本大道久久东京热无码AV| 国产亚洲精品美女久久久| 久久99久久成人免费播放| 少妇久久久久久久久久| 中文字幕亚洲综合久久| 久久综合给合久久狠狠狠97色| 精品国产热久久久福利| 精品久久久久香蕉网| 97精品伊人久久久大香线蕉| 亚洲美日韩Av中文字幕无码久久久妻妇| 久久国产亚洲高清观看| 亚洲中文字幕无码久久精品1| 午夜视频久久久久一区| 亚洲国产精品人久久| 69SEX久久精品国产麻豆| 亚洲国产精品无码久久98| 怡红院日本一道日本久久 | 国产亚洲精品自在久久| 亚洲精品国产美女久久久| 久久亚洲欧洲国产综合| 久久99精品久久久久久不卡| 久久免费国产精品一区二区| 99久久国产热无码精品免费| 亚洲国产欧洲综合997久久| 99久久做夜夜爱天天做精品| 午夜视频久久久久一区| 久久99国产精品久久99小说| 99久久精品国产一区二区| 一本久道久久综合狠狠爱| 久久久久久午夜成人影院| 久久超碰97人人做人人爱| 国产亚洲婷婷香蕉久久精品|