• <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++博客 :: 首頁 :: 聯(lián)系 ::  :: 管理
              163 Posts :: 4 Stories :: 350 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(48)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 400065
            • 排名 - 59

            最新評論

            閱讀排行榜

            評論排行榜

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

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

            (三)const+成員函數(shù)。任何不修改數(shù)據(jù)成員的函數(shù)都應該聲明為const類型,如果const成員函數(shù)修改了數(shù)據(jù)成員或者調(diào)用了其他函數(shù)修改數(shù)據(jù)成員,編譯器都將報錯!
            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 表示 指向的內(nèi)容不能改變
                2、char * const p,就是將P聲明為常指針,它的地址不能改變,是固定的,但是它的內(nèi)容可以改變。
                3、這種const指針是前兩種的結(jié)合,使得指向的內(nèi)容和地址都不能發(fā)生變化.
                     const double pi = 3.14159;
                     const double *const pi_ptr = &pi;
            posted on 2008-01-13 21:20 sdfasdf 閱讀(14694) 評論(7)  編輯 收藏 引用 所屬分類: C++

            Feedback

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

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

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

            3.函數(shù)返回值的時候,需要區(qū)分是否為內(nèi)置類型,內(nèi)置類型的返回值是一個右值,可以保證其不會被修改,但是返回自定義類型的時候,如果不加const,函數(shù)返回值是可以被賦值的,雖然不符合常理,但是語法上是沒問題的。
            例如 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: }

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

            # re: const的作用 2013-01-18 13:07 杜晶
            @TheAnswer
            你說的:內(nèi)置類型的返回值是一個右值,可以保證其不會被修改,倒是C編譯器在編譯語法檢查時就實現(xiàn)了的,我之所以同意你這個說法,是因為下面的代碼完全可以通過編譯:
            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語言里的函數(shù)定義時是不能在函數(shù)名后面加const的,加了反而是語法錯誤,C++中也只有類的成員函數(shù)名后才能加這個const,其他的時候const要加也只能加在返回值或者參數(shù)(變量)定義前,樓主說的完全正確。
              回復  更多評論
              

            # re: const的作用 2013-01-18 13:36 杜晶
            又做了一個實驗,內(nèi)容如下,應該更能說明問題:
            情況一:編譯通過!
            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;
            }
              回復  更多評論
              

            国内精品综合久久久40p| 99999久久久久久亚洲| 性高朝久久久久久久久久| 久久久久国色AV免费观看| 热综合一本伊人久久精品| 久久精品麻豆日日躁夜夜躁| 国产精品美女久久久免费| 伊人久久大香线蕉亚洲| 国产午夜电影久久| 久久精品黄AA片一区二区三区| 91精品婷婷国产综合久久| 亚洲日本va午夜中文字幕久久 | 久久久国产99久久国产一| 男女久久久国产一区二区三区| 99国产欧美精品久久久蜜芽| 国产成人无码精品久久久免费| 久久久久久无码国产精品中文字幕 | AV无码久久久久不卡蜜桃| 精品国产乱码久久久久久郑州公司| 国内精品九九久久久精品| 青青草原综合久久大伊人导航| 乱亲女H秽乱长久久久| 精品无码久久久久久久久久 | 少妇久久久久久被弄高潮| 久久午夜无码鲁丝片秋霞 | 亚洲狠狠婷婷综合久久久久| 国产亚洲婷婷香蕉久久精品| 看全色黄大色大片免费久久久| 久久免费的精品国产V∧| 久久久久国产日韩精品网站| 久久夜色精品国产噜噜麻豆| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 亚洲欧美另类日本久久国产真实乱对白 | 少妇久久久久久被弄到高潮| 久久国产欧美日韩精品| 久久天天躁夜夜躁狠狠| 久久久91精品国产一区二区三区| 久久亚洲国产成人精品无码区| 热99re久久国超精品首页| 潮喷大喷水系列无码久久精品| 久久综合亚洲色一区二区三区|