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

              C++博客 :: 首頁 :: 聯系 ::  :: 管理
              163 Posts :: 4 Stories :: 350 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(48)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 398977
            • 排名 - 59

            最新評論

            閱讀排行榜

            評論排行榜

                  const是C語言的一種關鍵字,起受保護,防止以外的變動的作用!可以修飾變量,參數,返回值,甚至函數體。const可以提高程序的健壯性,你只管用到你想用的任何地方。
            (一)const修飾參數。const只能修飾輸入參數。
               1、如果輸入參數是指針型的,用const修飾可以防止指針被意外修改。
               2、如果參數采用值傳遞的方式,無需const,因為函數自動產生臨時變量復制該參數。
               3、非內部數據類型的參數,需要臨時對象復制參數,而臨時對象的構造,析構,復制較為費時,因此建議采用前加const的引用方式傳遞非內部數據類型。而內部數據類型無需引用傳遞。

            (二)const修飾函數返回值。
               1、函數返回const指針,表示該指針不能被改動,只能把該指針賦給const修飾的同類型指針變量。
               2、函數返回值為值傳遞,函數會把返回值賦給外部臨時變量,用const無意義!不管是內部還是非內部數據類型。
               3、函數采用引用方式返回的場合不多,只出現在類的賦值函數中,目的是為了實現鏈式表達。

            (三)const+成員函數。任何不修改數據成員的函數都應該聲明為const類型,如果const成員函數修改了數據成員或者調用了其他函數修改數據成員,編譯器都將報錯!
            class stack
            {
            public:
            void push(int elem);
            void pop(void);
            int  GetCount(void) const ;
            private:
             int m_num;
             int m_date[10];
            };

            int stack::GetCount(void)   const
            {
             m_num++;
            }


            編譯器輸出錯誤信息:error C2166: l-value specifies const object。

            (四)const 修飾變量,表示該變量不能被修改。
                1、const char  *p 表示 指向的內容不能改變
                2、char * const p,就是將P聲明為常指針,它的地址不能改變,是固定的,但是它的內容可以改變。
                3、這種const指針是前兩種的結合,使得指向的內容和地址都不能發生變化.
                     const double pi = 3.14159;
                     const double *const pi_ptr = &pi;
            posted on 2008-01-13 21:20 sdfasdf 閱讀(14683) 評論(7)  編輯 收藏 引用 所屬分類: C++

            Feedback

            # re: const的作用 2008-01-14 05:44 TheAnswer
            隨便說幾點。

            1.const是C++中的關鍵字,C中的const是鑒戒C++定義的關鍵字,但是C中的const與C++比退化的很厲害,幾乎就是沒啥用。

            2.從語義上來講,函數參數中的指針不應該用const修飾,既然用指針傳遞,就應該意味著參數會被修改,如果函數體不修改參數,應該用const引用或者傳值。

            3.函數返回值的時候,需要區分是否為內置類型,內置類型的返回值是一個右值,可以保證其不會被修改,但是返回自定義類型的時候,如果不加const,函數返回值是可以被賦值的,雖然不符合常理,但是語法上是沒問題的。
            例如 A func(int);
            func(3) = A();
            編譯完全可以通過,你可以試一下。 :)  回復  更多評論
              

            # re: const的作用 2013-01-18 12:34 杜晶
            @TheAnswer
            20: int main(int argc, char* argv[])
            21: {
            00401130 push ebp
            00401131 mov ebp,esp
            00401133 push 0FFh
            00401135 push offset __ehhandler$_main (00412ef9)
            0040113A mov eax,fs:[00000000]
            00401140 push eax
            00401141 mov dword ptr fs:[0],esp
            00401148 sub esp,54h
            0040114B push ebx
            0040114C push esi
            0040114D push edi
            0040114E lea edi,[ebp-60h]
            00401151 mov ecx,15h
            00401156 mov eax,0CCCCCCCCh
            0040115B rep stos dword ptr [edi]
            22: func(3)=A();
            0040115D lea ecx,[ebp-14h]
            00401160 call @ILT+5(A::A) (0040100a)
            00401165 mov dword ptr [ebp-58h],eax
            00401168 mov eax,dword ptr [ebp-58h]
            0040116B mov dword ptr [ebp-5Ch],eax
            0040116E mov dword ptr [ebp-4],0
            00401175 mov ecx,dword ptr [ebp-5Ch]
            00401178 mov esi,dword ptr [ecx]
            0040117A push 3
            0040117C lea edx,[ebp-10h]
            0040117F push edx
            00401180 call @ILT+0(func) (00401005)
            00401185 add esp,8
            00401188 mov dword ptr [ebp-60h],eax
            0040118B mov eax,dword ptr [ebp-60h]
            0040118E mov dword ptr [eax],esi
            00401190 lea ecx,[ebp-10h]
            00401193 call @ILT+10(A::~A) (0040100f)
            00401198 mov dword ptr [ebp-4],0FFFFFFFFh
            0040119F lea ecx,[ebp-14h]
            004011A2 call @ILT+10(A::~A) (0040100f)
            23:
            24: return 0;
            004011A7 xor eax,eax
            25: }

            調試匯編下你們就知道了,func(3) = A();之所以可以編譯通過,是因為這句話相當于,A temp1=A::A(); A temp2=func(3); temp2=temp1;  回復  更多評論
              

            # re: const的作用 2013-01-18 13:07 杜晶
            @TheAnswer
            你說的:內置類型的返回值是一個右值,可以保證其不會被修改,倒是C編譯器在編譯語法檢查時就實現了的,我之所以同意你這個說法,是因為下面的代碼完全可以通過編譯:
            int func(int i){ return i;}
            int main(int argc, char* argv[])
            {
            const int a=func(1);
            func(2);
            __asm{
            mov a, eax;//修改a常量,說明匯編級并沒有所謂的左右值之說。
            }
            return 0;
            }

            左右值的編譯錯誤完全是在C/C++編譯器做語法檢查的時候就報錯了。  回復  更多評論
              

            # re: const的作用 2013-01-18 13:13 杜晶
            @TheAnswer
            另外樓主的描述我比較贊同,原因是C語言里的函數定義時是不能在函數名后面加const的,加了反而是語法錯誤,C++中也只有類的成員函數名后才能加這個const,其他的時候const要加也只能加在返回值或者參數(變量)定義前,樓主說的完全正確。
              回復  更多評論
              

            # re: const的作用 2013-01-18 13:36 杜晶
            又做了一個實驗,內容如下,應該更能說明問題:
            情況一:編譯通過!
            class A
            {
            const int m_i;
            public:
            A(): m_i(0){}
            ~A(){}
            /*const*/ A GetI(int i) const {return *this;}
            A operator =(A& a){return a;}
            };

            int main(int argc, char* argv[])
            {
            A a;
            /*(const class A)*/a.GetI(1)=/*(const class A)*/a.GetI(2);
            printf("Hello World!\n");
            return 0;
            }
              回復  更多評論
              

            # re: const的作用 2013-01-18 13:37 杜晶
            情況二:編譯報錯error C2678: binary '=' : no operator defined which takes a left-hand operand of type 'const class A' (or there is no acceptable conversion)

            class A
            {
            const int m_i;
            public:
            A(): m_i(0){}
            ~A(){}
            const A GetI(int i) const {return *this;}
            A operator =(A& a){return a;}
            };

            int main(int argc, char* argv[])
            {
            A a;
            /*(const class A)*/a.GetI(1)=/*(const class A)*/a.GetI(2);
            printf("Hello World!\n");
            return 0;
            }
              回復  更多評論
              

            # re: const的作用 2013-01-18 13:40 杜晶
            情況三:編譯通過,強行通知C/C++編譯器這個語法檢查正確。
            class A
            {
            const int m_i;
            public:
            A(): m_i(0){}
            ~A(){}
            const A GetI(int i) const {return *this;}
            A operator =(A& a){return a;}
            };

            int main(int argc, char* argv[])
            {
            A a;
            (const class A)a.GetI(1)=(const class A)a.GetI(2);
            printf("Hello World!\n");
            return 0;
            }
              回復  更多評論
              

            久久久久久久免费视频| 久久精品女人天堂AV麻| 久久精品中文无码资源站| 亚洲va久久久噜噜噜久久天堂| 久久精品国产精品亚洲毛片| 国产精品久久久久影院色| 久久久免费观成人影院| 亚洲精品无码专区久久久| 免费精品99久久国产综合精品| 欧美国产成人久久精品| …久久精品99久久香蕉国产| 日本加勒比久久精品| 久久免费线看线看| 久久精品国产亚洲av麻豆蜜芽| 99久久免费国产精品| 久久久久久久亚洲Av无码| 亚洲国产香蕉人人爽成AV片久久| 久久久亚洲欧洲日产国码aⅴ| 久久婷婷人人澡人人| 久久97精品久久久久久久不卡| 一本大道久久香蕉成人网| 国产真实乱对白精彩久久| 日韩精品久久无码人妻中文字幕 | .精品久久久麻豆国产精品| 久久无码国产| 久久夜色精品国产亚洲| 国内精品伊人久久久久av一坑| 亚洲国产成人久久笫一页| 精品久久久久久无码人妻蜜桃| 精品久久久久久中文字幕人妻最新| 尹人香蕉久久99天天拍| 久久天天躁狠狠躁夜夜2020| 国产免费久久精品99久久| 日本三级久久网| 秋霞久久国产精品电影院| 久久99精品久久久久久| 久久亚洲欧美国产精品| 精品久久久久中文字幕日本| 精品综合久久久久久888蜜芽| 久久国产高潮流白浆免费观看| 香蕉久久夜色精品升级完成|