• <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 - 319, comments - 22, trackbacks - 0, articles - 11
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            C++ const 用法

            Posted on 2011-08-10 07:25 RTY 閱讀(512) 評論(0)  編輯 收藏 引用 所屬分類: 編程常識C/C++
            http://www.diybl.com/course/3_program/c++/cppjs/20091022/179910.html

            1. const修飾普通變量和指針

            const修飾變量,一般有兩種寫法:

            const TYPE value;

            TYPE const value;

            這兩種寫法在本質上是一樣的。它的含義是:const修飾的類型為TYPE的變量value是不可變的。

            對于一個非指針的類型TYPE,無論怎么寫,都是一個含義,即value只不可變。

            例如:

            const int nValue;         //nValue是const

            int const nValue;    // nValue是const

            但是對于指針類型的TYPE,不同的寫法會有不同情況,例如:

            A. const char *pContent;

            B. char * const pContent;

            C. char const *pContent;

            D. const char* const pContent;

            對于前三種寫法,我們可以換個方式,給其加上括號

            A. const (char) *pContent;

            B. (char*) const pContent;

            C. (char) const *pContent;

            這樣就一目了然。根據對于const修飾非指針變量的規則,很明顯,A=C.

            - 對于A,C, const修飾的類型為char的變量*pContent為常量,因此,pContent的內容為常量不可變.

            - 對于B, 其實還有一種寫法: const (char*) pContent;

            含義為:const修飾的類型為char*的變量pContent為常量,因此,pContent指針本身為常量不可變.

            - 對于D, 其實是A和B的混合體,表示指針本身和指針內容兩者皆為常量不可變

            總結:

            (1)  指針本身是常量不可變

            (char*) const pContent;

            const (char*) pContent;

            (2)  指針所指向的內容是常量不可變

            const (char) *pContent;

            (char) const *pContent;

            (3)  兩者都不可變

            const char* const pContent;

            還有其中區別方法:

            沿著*號劃一條線,

            如果const位于*的左側,則const就是用來修飾指針所指向的變量,即指針指向為常量;

            如果const位于*的右側,const就是修飾指針本身,即指針本身是常量。 
            2. const修飾函數參數

            const修飾函數參數是它最廣泛的一種用途,它表示函數體中不能修改參數的值(包括參數本身的值或者參數其中包含的值)。它可以很好 
            void function(const int Var); //傳遞過來的參數在函數內不可以改變(無意義,因為Var本身就是形參)

            void function(const char* Var); //參數指針所指內容為常量不可變

            void function(char* const Var); //參數指針本身為常量不可變(也無意義, 因為char* Var也是形參)

            參數為引用,為了增加效率同時防止修改。

            修飾引用參數時:

            void function(const Class& Var);//引用參數在函數內不可以改變

            void function(const TYPE& Var); //引用參數在函數內為常量不可變

            3. const 修飾函數返回值

            const修飾函數返回值其實用的并不是很多,它的含義和const修飾普通變量以及指針的含義基本相同。

            (1) const int fun1() 這個其實無意義,因為參數返回本身就是賦值。

            (2) const int * fun2()

            調用時 const int *pValue = fun2();

            我們可以把fun2()看作成一個變量,那么就是我們上面所說的1.(1)的寫法,即指針內容不可變。

            (3) int* const fun3()

            調用時 int * const pValue = fun2();

            我們可以把fun2()看作成一個變量,那么就是我們上面所說的1.(2)的寫法,即指針本身不可變。

            4. const修飾類對象/對象指針/對象引用

            const修飾類對象表示該對象為常量對象,其中的任何成員都不能被修改。對于對象指針和對象引用也是一樣。

            const修飾的對象,該對象的任何非const成員函數都不能被調用,因為任何非const成員函數會有修改成員變量的企圖。

            例如:

            class AAA

            {
               void func1();

            void func2() const;

            }

            const AAA aObj;

            aObj.func1(); ×

            aObj.func2(); 正確

            const AAA* aObj = new AAA();

            aObj->func1(); ×

            aObj->func2(); 正確 
            5. const修飾成員變量

            const修飾類的成員函數,表示成員常量,不能被修改,同時它只能在初始化列表中賦值。 
            class A

            {

               …

               const int nValue;       //成員常量不能被修改

               …

               A(int x): nValue(x) {}; //只能在初始化列表中賦值


            6. const修飾成員函數

            const修飾類的成員函數,則該成員函數不能修改類中任何非const成員函數。一般寫在函數的最后來修飾。
            class A

            {

               …

            void function()const; //常成員函數, 它不改變對象的成員變量. 也不能調用類中任何非const成員函數。

            }

            對于const類對象/指針/引用,只能調用類的const成員函數,因此,const修飾成員函數的最重要作用就是限制對于const對象的使用。 
            7. const常量與define宏定義的區別

            (1) 編譯器處理方式不同

            define宏是在預處理階段展開。

            const常量是編譯運行階段使用。

            (2) 類型和安全檢查不同

            define宏沒有類型,不做任何類型檢查,僅僅是展開。

            const常量有具體的類型,在編譯階段會執行類型檢查。

            (3) 存儲方式不同

            define宏僅僅是展開,有多少地方使用,就展開多少次,不會分配內存。

            const常量會在內存中分配(可以是堆中也可以是棧中)。


            国产亚州精品女人久久久久久 | 无码人妻精品一区二区三区久久久 | 久久久久se色偷偷亚洲精品av| 亚洲七七久久精品中文国产| 欧美久久久久久| 人妻精品久久无码专区精东影业| 亚洲国产精品无码久久久蜜芽| 色狠狠久久AV五月综合| 97久久精品无码一区二区天美| 久久国产精品成人免费| 手机看片久久高清国产日韩| 性做久久久久久久| 久久播电影网| 久久久久AV综合网成人| 国产精自产拍久久久久久蜜| 亚洲国产精品高清久久久| 亚洲综合精品香蕉久久网97| 久久无码国产专区精品| 好属妞这里只有精品久久| 久久亚洲sm情趣捆绑调教 | 伊人久久大香线蕉综合网站| 久久99精品久久只有精品| 污污内射久久一区二区欧美日韩 | 久久精品aⅴ无码中文字字幕不卡| 国内精品免费久久影院| 国产V亚洲V天堂无码久久久| 日本加勒比久久精品| 99久久国产综合精品成人影院| 色婷婷综合久久久久中文一区二区| 色诱久久av| 亚洲国产日韩欧美久久| 精品国产91久久久久久久a| 国产亚洲美女精品久久久久狼| 亚洲中文字幕无码久久精品1| 深夜久久AAAAA级毛片免费看 | 亚洲国产精品久久久久婷婷软件 | 久久婷婷激情综合色综合俺也去| 日本精品一区二区久久久| 久久亚洲精品无码观看不卡| 国产成人AV综合久久| 精品水蜜桃久久久久久久|