• <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++博客 首頁 新隨筆 聯系 聚合 管理
              20 Posts :: 0 Stories :: 10 Comments :: 0 Trackbacks
            1.修飾類的數據成員
            const數據成員只是在某個對象的生命周期內是常量.如果創建多個對象,那么每個對象的const數據成員可以不一樣.所以,不能在類聲明中初始化const數據成員.如:
            class A
            {
            ???const int size = 100;//?錯誤
            ???int array[size];//錯誤,未知的數組大小
            }
            const類數據成員,只能在類的構造函數的初始化列表中進行.要想建立整個類都是恒定的常量的數據,可以用類中的枚舉.如:
            class A
            {
            enum {size1 = 100, size2 = 200};
            int array[size1];
            }

            2.只有聲明為const的成員函數才能被一個const對象調用

            3.在另一連接文件中引用const常量.
            extern const int i

            4.對于const對象,c++既允許對其進行靜態初始化,也允許對其進行動態初始化.const對象具有從構造函數完成到析構函數執行之前的不變性.

            5.常量與數組的組合有什么特殊嗎?
            我們給出下面的代碼:
            const int size[3]={10,20,50};
            int array[size[2]];
            編譯通不過!為什么呢?const可以用于集合,但編譯器不能把一個集合存放在它的符號表里,所以必須分配內存。在這種情況下,const意味著“不能改變的一塊存儲”。然而,其值在編譯時不能被使用,因為編譯器在編譯時不需要知道存儲的內容。自然,作為數組的大小就不行了
            你再看看下面的例子:
            class A
            {
            public:
            A(int i=0):test[2]({1,2}) {} file://你/認為行嗎?
            private:
            const int test[2];
            };
            C++標準有一個規定,不允許無序對象在類內部初始化,數組顯然是一個無序的,所以這樣的初始化是錯誤的!對于他,只能在類的外部進行初始化,如果想讓它通過,只需要聲明為靜態的,然后初始化。
            這里我們看到,常量與數組的組合沒有什么特殊!一切都是數組惹的禍!

            (7)什么情況下為const分配內存?
            以下是我想到的可能情況,當然,有的編譯器進行了優化,可能不分配內存。
            A、作為非靜態的類成員時;
            B、用于集合時;
            C、被取地址時;
            D、在main函數體內部通過函數來獲得值時;
            E、const的 class或struct有用戶定義的構造函數、析構函數或基類時;。
            F、當const的長度比計算機字長還長時;
            G、參數中的const;
            H、使用了extern時。

            (8)與static搭配會不會有問題?
            假設有一個類:
            class A
            {
            public:
            ......
            static void f() const { ......}
            ......
            };
            我們發現編譯器會報錯,因為在這種情況下static不能夠與const共存!因為static沒有this指針,但是const修飾this指針.

            (9)如何修改常量?
            有時候我們卻不得不對類內的數據進行修改,但是我們的接口卻被聲明了const,那該怎么處理呢?我對這個問題的看法如下:
            1)標準用法:mutable
            class A
            {
            public:
            A(int i=0):test(i) { }
            void Setvalue(int i)const { test=i; }
            private:
            mutable int test; file://這/里處理!
            };
            2)強制轉換:const_cast
            class A
            {
            public:
            A(int i=0):test(i) { }
            void Setvalue(int i)const
            { const_cast <int>(test)=i; }//這里處理!
            private:
            int test;
            };

            (10)最后我們來討論一下常量對象的動態創建。
            既然編譯器可以動態初始化常量,就自然可以動態創建,例如:
            const int* pi=new const int(10);
            這里要注意2點:
            1)const對象必須被初始化!所以(10)是不能夠少的。
            2)new返回的指針必須是const類型的。
            那么我們可不可以動態創建一個數組呢?
            答案是否定的,因為new內置類型的數組,不能被初始化。
            posted on 2006-06-14 17:49 一動不如一靜 閱讀(434) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久国产欧美日韩精品| 国产—久久香蕉国产线看观看| 青草国产精品久久久久久| 久久国产热精品波多野结衣AV| 亚洲精品无码成人片久久| 久久国产精品成人片免费| 日韩欧美亚洲综合久久影院d3| 久久精品亚洲福利| 欧洲人妻丰满av无码久久不卡| 久久综合久久综合久久综合| 人妻少妇精品久久| 国产午夜福利精品久久2021| 久久福利片| 久久91综合国产91久久精品| 久久久久久精品久久久久| 国产精品成人99久久久久 | 久久久午夜精品福利内容| 久久人妻少妇嫩草AV蜜桃| 人人狠狠综合久久亚洲88| 亚洲精品tv久久久久久久久| 久久中文精品无码中文字幕| 久久66热人妻偷产精品9| 国内精品伊人久久久影院| 国产亚洲色婷婷久久99精品91| 性做久久久久久久| 欧美日韩精品久久久久| 久久婷婷五月综合97色直播| 国产成人99久久亚洲综合精品| 国内精品久久久久久久97牛牛| 国产精品久久久久久久人人看| 成人亚洲欧美久久久久| 久久99免费视频| 国产精品青草久久久久婷婷| 亚洲va久久久噜噜噜久久| 久久精品国产久精国产果冻传媒| 久久免费国产精品| 久久久久国色AV免费观看| 久久国产精品免费一区二区三区| 日本三级久久网| 亚洲国产精品久久久久婷婷软件 | 欧美激情精品久久久久久|