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

            Design&Art

            C++博客 首頁 新隨筆 聯系 聚合 管理
              26 Posts :: 0 Stories :: 38 Comments :: 0 Trackbacks
            一、對于基本聲明 

            1.const int r=100; //標準const變量聲明加初始化,因為默認內部連接所以必須被初始化,其作用域為此文件,編譯器經過類型檢查后直接用100在編譯時替換。 

            2.extend const int r=100; //將const改為外部連接,作用于擴大至全局,編譯時會分配內存,并且可以不進行初始化,僅僅作為聲明,編譯器認為在程序其他地方進行了定義。 

            3.const int r[ ]={1,2,3,4}; 

            struct S {int a,b;}; 
            const S s[ ]={(1,2),(3.4)}; //以上兩種都是常量集合,編譯器會為其分配內存,所以不能在編譯期間使用其中的值,例如:int temp[r[2]];這樣的編譯器會報告不能找到常量表達式 

            二、對于指針 
            1.const int *r=&x; //聲明r為一個指向常量的x的指針,r指向的對象不能被修改,但他可以指向任何地址的常量。 

            2.int const *r=&x; //與用法1完全等價,沒有任何區別。 

            3.int * const r=&x; //聲明r為一個常量指針,他指向x,r這個指針的指向不能被修改,但他指向的地址的內容可以修改。 

            4.const int * const r=&x; //綜合1、3用法,r是一個指向常量的常量型指針。 

            三、對于類型檢查 
            可以把一個非const對象賦給一個指向const的指針,因為有時候我們不想從這個指針來修改其對象的值;但是不可以把一個const對象賦值給一個非const指針,因為這樣可能會通過這個指針改變指向對象的值,但也存在使這種操作通過的合法化寫法,使用類型強制轉換可以通過指針改變const對象: 

            const int r=100; 
            int * ptr = const_cast<int *>(&r); //C++標準,C語言使用:int * ptr =(int*)&r; 

            四、對于字符數組 
            如char * name = “china”; 這樣的語句,在編譯時是能夠通過的,但是”china”是常量字符數組,任何想修改他的操作也能通過編譯但會引起運行時錯誤,如果我們想修改字符數組的話就要使用char name[ ] = “china”; 這種形式。 

            五、對于函數 
            1.void Fuction1 ( const int r ); //此處為參數傳遞const值,意義是變量初值不能被函數改變 

            2.const int Fuction1 (int); //此處返回const值,意思指返回的原函數里的變量的初值不能被修改,但是函數按值返回的這個變量被制成副本,能不能被修改就沒有了意義,它可以被賦給任何的const或非const類型變量,完全不需要加上這個const關鍵字。但這只對于內部類型而言(因為內部類型返回的肯定是一個值,而不會返回一個變量,不會作為左值使用),對于用戶自定義類型,返回值是常量是非常重要的,見下面條款3。 

            3.Class CX; //內部有構造函數,聲明如CX(int r =0) 

            CX Fuction1 () { return CX(); } 

            const CX Fuction2 () { return CX(); } 

            如有上面的自定義類CX,和函數Fuction1()和Fuction2(),我們進行如下操作時: 

            Fuction1() = CX(1); //沒有問題,可以作為左值調用 

            Fuction2() = CX(1); //編譯錯誤,const返回值禁止作為左值調用。因為左值把返回值作為變量會修改其返回值,const聲明禁止這種修改。 


            4.函數中指針的const傳遞和返回: 

            int F1 (const char * pstr); //作為傳遞的時候使用const修飾可以保證不會通過這個指針來修改傳遞參數的初值,這里在函數內部任何修改*pstr的企圖都會引起編譯錯誤。 

            const char * F2 (); //意義是函數返回的指針指向的對象是一個const對象,它必須賦給一個同樣是指向const對象的指針。 

            const char * const F3(); //比上面多了一個const,這個const的意義只是在他被用作左值時有效,它表明了這個指針除了指向const對象外,它本身也不能被修改,所以就不能當作左值來處理。 


            5.函數中引用的const傳遞: 

            void F1 ( const X& px); //這樣的一個const引用傳遞和最普通的函數按值傳遞的效果是一模一樣的,他禁止對引用的對象的一切修改,唯一不同的是按值傳遞會先建立一個類對象的副本,然后傳遞過去,而它直接傳遞地址,所以這種傳遞比按值傳遞更有效。 

            **另外只有引用的const傳遞可以傳遞一個臨時對象,因為臨時對象都是const屬性,且是不可見的,他短時間存在一個局部域中,所以不能使用指針,只有引用的const傳遞能夠捕捉到這個家伙。 

            六、對于類 
            1.首先,對于const的成員變量,只能在構造函數里使用初始化成員列表來初始化,試圖在構造函數體內進行初始化const成員變量會引起編譯錯誤。初始化成員列表形如: 
            2.X:: X ( int ir ): r(ir) {} //假設r是類X的const成員變量 

            2.const成員函數。提到這個概念首先要談到const對象,正象內置類型能夠定義const對象一樣(const int r=10;),用戶自定義類型也可以定義const對象(const X px(10);),編譯器要保證這個對象在其生命周期內不能夠被改變。如果你定義了這樣的一個const對象,那么對于這個對象的一切非const成員函數的調用,編譯器為了保證對象的const特性,都會禁止并在編譯期間報錯。所以如果你想讓你的成員函數能夠在const對象上進行操作的話,就要把這個函數聲明為const成員函數。假如f( )是類中的成員函數的話,它的聲明形如: 
            int f( ) const; //const放在函數的最后,編譯器會對這個函數進行檢查,在這個函數中的任何試圖改變成員變量和調用非const成員函數的操作都被視為非法 
            注意:類的構造和析構函數都不能是const函數。 

            3.建立了一個const成員函數,但仍然想用這個函數改變對象內部的數據。這樣的一個要求也會經常遇到,尤其是在一個苛刻的面試考官那里。首先我們要弄清楚考官的要求,因為有兩種方法可以實現,如果這位考官要求不改變原來類的任何東西,只讓你從當前這個const成員函數入手,那么你只有使用前面提到的類型強制轉換方法。實例如下: 

            //假如有一個叫做X的類,它有一個int成員變量r,我們需要通過一個const成員函數f( )來對這個r進行++r操作,代碼如下 

            void X::f( ) const 

            { (const_cast(this)) -> ++r; } //通過this指針進行類型強制轉換實現 

            另外一種方法就是使用關鍵字:mutable。如果你的成員變量在定義時是這個樣子的: 

            mutable int r ; 

            那么它就告訴編譯器這個成員變量可以通過const成員函數改變。編譯器就不會再理會對他的檢查了。 
            posted on 2009-04-11 00:51 安帛偉 閱讀(341) 評論(0)  編輯 收藏 引用 所屬分類: C++
            狠狠综合久久综合88亚洲| 少妇久久久久久被弄到高潮| 无码国产69精品久久久久网站| 久久这里都是精品| 久久精品人人做人人爽电影| 精品国产乱码久久久久久呢| 国产精品一久久香蕉国产线看观看| 国产精品久久久久久影院| 久久精品国产亚洲5555| 人妻无码中文久久久久专区 | 久久99精品久久久久久不卡| 久久久久久噜噜精品免费直播 | 免费一级做a爰片久久毛片潮| 亚洲国产成人精品女人久久久 | 精品一区二区久久久久久久网站| 国产亚洲精午夜久久久久久 | 久久五月精品中文字幕| 伊人久久大香线蕉亚洲| 久久99国产精品成人欧美| 99久久精品国产麻豆| 久久亚洲日韩看片无码| 精品水蜜桃久久久久久久| 成人久久久观看免费毛片| 色婷婷综合久久久久中文一区二区| 99久久精品免费观看国产| 婷婷久久香蕉五月综合加勒比| 久久国产精品99久久久久久老狼| 国产成人精品久久免费动漫| 久久人人超碰精品CAOPOREN| 久久久无码精品亚洲日韩蜜臀浪潮| 精品国产综合区久久久久久 | 久久国产乱子伦精品免费午夜| 久久国产高潮流白浆免费观看| 亚洲国产香蕉人人爽成AV片久久 | 久久国产免费直播| 久久久久久A亚洲欧洲AV冫| 久久精品www| 久久久久夜夜夜精品国产| 97久久久久人妻精品专区| 久久精品一区二区三区AV| 久久久午夜精品福利内容|