• <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>
            隨筆-2  評論-16  文章-0  trackbacks-0

            C++中const用法總結

            作者JuKevin

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

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

            const TYPE value;

            TYPE const value;

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

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

            例如:

            const int nValue         //nValueconst

            int const nValue    // nValueconst

            但是對于指針類型的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, 其實是AB的混合體,表示指針本身和指針內容兩者皆為常量不可變

             

            總結:

            (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常量會在內存中分配(可以是堆中也可以是棧中)

            posted on 2008-12-27 12:07 JuKevin 閱讀(18590) 評論(16)  編輯 收藏 引用

            評論:
            # re: C++中const用法總結[未登錄] 2008-12-27 12:54 | 關中刀客
            我們有些同志啊,總是濫用這個const
            例如 :
            int add(const int a, const int b)
            {
            return a+b;
            }
            仔細看看,這些要這個const要什么用?荒誕!  回復  更多評論
              
            # re: C++中const用法總結 2008-12-27 13:33 | JuKevin
            To 關中刀客
            你說的對,因此我們更要詳細的去掌握const的每個用法的細節  回復  更多評論
              
            # re: C++中const用法總結[未登錄] 2008-12-27 13:57 | Robin
            @關中刀客
            傳值方式時用const修飾參數確實沒有意義……相當于調用了拷貝構造函數,而拷貝構造的函數的參數為const引用。  回復  更多評論
              
            # re: C++中const用法總結 2008-12-27 18:37 | zwp
            @關中刀客
            如果就你提供的那個例子而言,const缺失沒什么作用,少了他顯得簡潔。
            但是我不反對加上他。
            姑且不說這樣的函數存在是否有意義,不說他的命名是否合適,既然作為一個單獨的函數實體,至少實現了一定的抽象。而這代表著未來他是可變的。假設未來你需要重構這個函數的時候,你會發現const的好處的。
            并且這里的意圖很明顯,不要修改這個臨時參數的值,也算是一種實現上的約束了,使得未來的重構或者升級有更多的選擇空間。
            我覺得const怎么用都不為過分。  回復  更多評論
              
            # re: C++中const用法總結 2008-12-27 19:23 | wufa
            是誰說過:一切默認其為const后,再來考慮不能為const的情況,而不是反過來.  回復  更多評論
              
            # re: C++中const用法總結 2009-03-06 14:08 | 一葦
            學習了 謝謝分享  回復  更多評論
              
            # re: C++中const用法總結 2010-01-13 13:54 | 過客匆匆
            學習了!雖然還是有點迷惑。const的使用規則真是眾說紛紜啊。。。  回復  更多評論
              
            # re: C++中const用法總結 2010-04-28 08:47 | 瞅了一眼
            初學者不能只看,還是多練習一下,編譯運行感覺一下,看百遍不如用幾遍,切記切記  回復  更多評論
              
            # re: C++中const用法總結 2011-05-03 11:02 | bobbyyu
            作為一種意圖的表達,這樣的寫法其實是有意義的,因為add函數的意圖應該排除對參數本身內容的修改,const正好表達這個約束,如下面的代碼就編譯不過去:
            int add(const int a, const int b)
            {
            a++;
            b++;
            return a + b;
            }
              回復  更多評論
              
            # re: C++中const用法總結 2011-11-14 17:09 | allanbolt
            對于B, 其實還有一種寫法: const (char*) pContent;

            含義為:const修飾的類型為char*的變量pContent為常量,因此,pContent指針本身為常量不可變.
            樓主:
            const (char*) pContent;
            在VS2008 測試下發現此表達式含義是 pContent指針指向的變量為常量   回復  更多評論
              
            # re: C++中const用法總結 2012-02-28 10:56 | everyoung
            總結的蠻好~~  回復  更多評論
              
            # re: C++中const用法總結 2013-10-18 20:12 | foxandhuzh
            贊一下,樓主總結得很清楚。
            @allanbolt
            不過這幾個:
            char greeting[10] = "Hello!";
            const (char*) p5 = greeting;
            const (char) *p6 = greeting;
            (char*) const p7 = greeting;
            (char) const *p8 = greeting;
            也就是帶括號的,在VC6.0和VS2008都下編譯不過去啊。

            還是用const在星號前還是星號后區分比較清楚  回復  更多評論
              
            # re: C++中const用法總結 2013-10-18 21:24 | foxandhuzh
            @關中刀客
            int add(const int a, const int b)
            {
            return a+b;
            }
            這里的const仍然是有意義的,只是因為程序太簡短了,所以顯得冗余。

            倘若不是類似a+b這么簡單的程序,給內置類型的函數變量加上const還是有必要的,因為程序的長度可能隨著開發而增長,const提醒程序員這是個不變的量,不得擅自修改。  回復  更多評論
              
            # re: C++中const用法總結 2014-07-07 14:26 | test
            @關中刀客
            是因為你膚淺!做參數加了const,在函數體里面,就沒有對a b做寫入操作 比如a++,這個叫參數保護  回復  更多評論
              
            # re: C++中const用法總結 2015-10-12 17:32 | wildangel817
            樓主,有如下聲明:
            template<typename Key, typename ParamValue>
            int CTableBaseOper<Key, ParamValue>::SetMapParam( Key TEMP_Key, ParamValue TEMP_Value, int iValueSize )
            {
            //..
            }

            如何實現如下的函數調用呢?

            int SetValue( int Id, const A *AValue )
            {
            SetMapParam(Id, AValue , iSize);
            }  回復  更多評論
              
            # re: C++中const用法總結[未登錄] 2015-12-04 19:23 | jacky
            @zwp
            同意  回復  更多評論
              
            国产精品乱码久久久久久软件| 99精品久久精品一区二区| 美女写真久久影院| 久久综合视频网站| 久久99久国产麻精品66| 国产精品对白刺激久久久| 久久99精品久久久久久噜噜| 国产成人精品综合久久久久 | 久久亚洲精品国产亚洲老地址 | 色综合久久精品中文字幕首页| 久久久久久久亚洲精品| 午夜欧美精品久久久久久久| 久久这里只有精品久久| 亚洲va久久久噜噜噜久久男同 | 久久精品免费大片国产大片| 中文字幕人妻色偷偷久久 | 狠狠综合久久综合88亚洲| 99久久精品久久久久久清纯| 午夜不卡久久精品无码免费| 久久最新免费视频| 国产午夜精品久久久久九九电影 | 久久久久久亚洲精品无码| 韩国免费A级毛片久久| 东方aⅴ免费观看久久av| 欧美日韩精品久久久免费观看 | 一本久道久久综合狠狠躁AV| 青青草原1769久久免费播放| 久久99精品国产自在现线小黄鸭 | 狠狠色噜噜色狠狠狠综合久久| 久久精品女人天堂AV麻| 99久久成人18免费网站| 久久国产精品一区二区| 国产精品免费福利久久| 久久综合噜噜激激的五月天| 久久久久久曰本AV免费免费| 亚洲а∨天堂久久精品9966| 久久久精品日本一区二区三区| 久久国产视频网| 久久综合色老色| 无码精品久久久天天影视| 亚洲欧美日韩中文久久|