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

            Benjamin

            靜以修身,儉以養德,非澹薄無以明志,非寧靜無以致遠。
            隨筆 - 397, 文章 - 0, 評論 - 196, 引用 - 0
            數據加載中……

            C++中的訪問控制探究

            C++中訪問控制符有三個privtae、provected、public。public可以被所有人訪問,private出來該類的創建者和類的內部成員方法外,均不能訪問,provected和private相似,不過繼承類可以訪問基類的保護成員不能直接訪問基類的私有成員。前些天有人對下面的代碼中的部分感到不可理解,貼出來說說的而我自己的看法。代碼如下:

            using namespace std;

            class RMB
            {
            public:
             RMB(unsigned int d,unsigned int c);
             friend RMB operator + (RMB&,RMB&);
             friend RMB& operator ++ (RMB&);
             void Display(RMB& a,RMB& b);
             void Play(void)
             {
              int c = A+c;

             }
             
            private:
             int A;
             int C;
            public:
             void display()
             {
              cout << (yuan + jf / 100.0) << endl;
             }
            protected:
             unsigned int yuan;
             unsigned int jf;
            };

            void RMB::Display(RMB& a,RMB& b)
            {
             int k = a.A + b.C;//a為何能訪問private成員
             int c = a.yuan;
             //cout << "c=" << c << endl;
             cout << "k=" << k << endl;
            }

            RMB::RMB(unsigned int d,unsigned int c)
            {
             yuan = d;
             jf = c;
             while(jf >= 100)
             {
              yuan ++;
              jf -= 100;
             }

             A = d + 1;
             C = c + 1;
            }

            RMB operator + (RMB& s1,RMB& s2)
            {
             unsigned int jf = s1.jf + s2.jf;//這里為何可以訪問protected成員,s1是RMB的類對象,jf是被protected成員
             unsigned int yuan = s1.yuan + s2.yuan;
             RMB result(yuan,jf);
             return(result);
            }

            RMB& operator ++ (RMB& s)
            {
             s.jf++;
             if (s.jf >= 100)
             {
              s.jf -= 100;
              s.yuan ++;
             }

             return s;
            }

            int _tmain(int argc, _TCHAR* argv[])
            {
             RMB d1(1,60);
             RMB d2(2,50);
             RMB d3(10,10);

             d3 = d1 + d2;
             ++ d3;
             d3.Display(d1,d2);
             d3.display();
             getchar();
             
             return 0;
            }

            乍一看,肯定通不過編譯,事實是可以正確的運行,我用的是VC8編譯器。
            RMB類的方法(Display、Paly)可以訪問它的protected和private成員,但是當它的參數是RMB類對象的引用,為何也能訪問它的private和proteceted成員?看起來簡單的問題,但是很讓人思考,其實看看它們的作用域就明白了。protected和private只有類的內部方法可以訪問,在看看函數形參數的作用域,就好解釋了。friend只是類的另一個接口,它打破了類的封裝性,很多人不提倡用它,但是我們姑且把它當作類的一個緊急接口,不到萬不得已不用它就可以,它沒有訪問限制,位置放到哪里都一樣。
            有些概念看起來簡單,但是要理解透徹,卻不是那么容易的,C++的許多概念都是如此,也是它的魅力所在。

            posted on 2009-03-01 10:23 Benjamin 閱讀(870) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            午夜精品久久久久成人| 91精品无码久久久久久五月天| 久久国产免费直播| 国产成人精品综合久久久| 久久国产精品二国产精品| 久久天天躁狠狠躁夜夜2020一| 久久亚洲中文字幕精品有坂深雪| 中文字幕亚洲综合久久| 久久精品国产亚洲5555| 久久久久久久久久久精品尤物| 久久无码人妻一区二区三区| 久久精品国产99久久丝袜| 久久精品一本到99热免费| 亚洲午夜无码AV毛片久久| 久久精品国产福利国产秒| 国产美女亚洲精品久久久综合 | 久久婷婷色综合一区二区| 99久久免费国产特黄| 久久国产色av免费看| 久久无码一区二区三区少妇| 国产精品久久久久影院嫩草| 亚洲中文字幕无码一久久区| 久久精品夜色噜噜亚洲A∨| 国产精品久久成人影院| 中文字幕热久久久久久久| 亚洲精品综合久久| 久久人人爽人人爽AV片| 久久精品国产亚洲一区二区三区| 国产精品久久久久久久久鸭| 国产成人精品白浆久久69| 久久精品中文騷妇女内射| 午夜欧美精品久久久久久久| 久久精品国产99久久久古代 | 国产精品综合久久第一页| 2021国产精品午夜久久| 久久人人爽人人精品视频| 久久综合久久伊人| 亚洲国产成人久久综合区| 久久久久亚洲av综合波多野结衣 | 久久青青国产| 久久97久久97精品免视看秋霞|