• <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 閱讀(873) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            精品久久久久久国产 | 岛国搬运www久久| 国产精品久久久久久福利漫画| 丰满少妇人妻久久久久久4| 亚洲午夜无码久久久久小说| 亚洲精品国产自在久久| 久久99精品久久久久久hb无码 | 久久艹国产| 国产精品中文久久久久久久| 久久久久AV综合网成人 | 91精品国产91久久| av色综合久久天堂av色综合在| 国产精品成人无码久久久久久| 欧美大香线蕉线伊人久久| 久久国产精品波多野结衣AV| 精品久久久无码21p发布| 久久久久亚洲精品男人的天堂| 久久精品一区二区国产| 热久久国产欧美一区二区精品| 久久99国产精一区二区三区| 久久久久亚洲Av无码专| 久久婷婷色香五月综合激情| 高清免费久久午夜精品| 漂亮人妻被黑人久久精品| 日日狠狠久久偷偷色综合96蜜桃 | 色综合久久中文字幕无码| 国产精品青草久久久久福利99 | 久久天天躁狠狠躁夜夜96流白浆| 欧美午夜精品久久久久久浪潮| 香蕉久久夜色精品国产小说| 久久夜色精品国产噜噜麻豆| 久久久久亚洲精品天堂久久久久久 | 精品多毛少妇人妻AV免费久久 | 精品久久一区二区| 久久香综合精品久久伊人| 72种姿势欧美久久久久大黄蕉| 亚洲国产欧美国产综合久久| 亚洲国产精品狼友中文久久久| 久久人人爽人人爽人人片AV东京热 | 热re99久久精品国99热| avtt天堂网久久精品|