• <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>
            隨筆 - 2, 文章 - 0, 評(píng)論 - 4, 引用 - 0
            數(shù)據(jù)加載中……

            通過(guò)指針訪問(wèn)類的私有數(shù)據(jù)成員

            我們知道在C++中,為了防止某些數(shù)據(jù)成員或成員函數(shù)從外部被直接訪問(wèn),可以將它們聲明為private,這樣編譯器會(huì)阻止任何來(lái)自外部非友元的直接訪問(wèn)。

            那么我們真的就沒(méi)辦法直接修改類的私有數(shù)據(jù)成員了嗎?

            來(lái)看一段代碼:

             1 #include <iostream>
             2 using namespace std;
             3 
             4 
             5 class A
             6 {
             7 private:
             8     // a & b are private members of class A
             9     int a;
            10     double b;
            11 public:
            12     // initialize a & b as value 0
            13     A() : a(0), b(0) {}
            14 
            15 public:
            16     // for display the value of a & b
            17     int GetA();
            18     double GetB();
            19 };
            20 
            21 int A::GetA()
            22 {
            23     return a;
            24 }
            25 
            26 double A::GetB()
            27 {
            28     return b;
            29 }
            30 
            31 int _tmain(int argc, _TCHAR* argv[])
            32 {
            33     A test;
            34 
            35     cout << "before pointer access:\n"
            36          << " test.a = " << test.GetA() << "\n"
            37          << " test.b = " << test.GetB() << "\n" << endl;
            38 
            39     // access object test of class A by pointer
            40     int* privateA = reinterpret_cast<int*>(&Test);
            41     double* privateB = reinterpret_cast<double*>(&Test) + 1;
            42 
            43     // value changing by pointer!
            44     *privateA = 1;
            45     *privateB = 2.5;
            46 
            47     cout << "after pointer access:\n"
            48          << " test.a = " << test.GetA() << "\n"
            49          << " test.b = " << test.GetB() << "\n" << endl;
            50 
            51     return 0;
            52 }
            53 


            運(yùn)行后輸出結(jié)果為:
            before pointer access:
             test.a = 0
             test.b = 0

            after pointer access:
             test.a = 1
             test.b = 2.5

            可以看到,雖然我們已經(jīng)將 A::a 和 A::b聲明為 private ,但在強(qiáng)大的指針面前,類的任何細(xì)節(jié)都暴露無(wú)遺。

            某種程度上,類的一個(gè)對(duì)象可以看作包含不同類型元素的數(shù)組,其數(shù)據(jù)成員的地址偏移由數(shù)據(jù)成員在類定義中的順序決定——類對(duì)象的地址指向類中第一個(gè)被定義的數(shù)據(jù)成員的地址;第二個(gè)被定義的數(shù)據(jù)成員的地址取決于第一個(gè)數(shù)據(jù)成員的類型,若第一個(gè)為 int 型,則再偏移 4 個(gè)字節(jié)( sizeof(int) )即得到第二個(gè)數(shù)據(jù)成員的地址(有時(shí)也不一定是這樣,如上例中,由于類型對(duì)齊的緣故,實(shí)際偏移 8 個(gè)字節(jié)( sizeof(double) )才得到第二個(gè)數(shù)據(jù)成員的地址,具體內(nèi)容不在本文討論范圍內(nèi))。

            所以即使你將其他所有細(xì)節(jié)都隱藏在 cpp 中,但頭文件中不可避免地會(huì)出現(xiàn)私有數(shù)據(jù)成員的聲明。而類的其他用戶只要能看到這個(gè)聲明,就能推算出類中各數(shù)據(jù)成員的相對(duì)地址偏移,從而用指針輕松實(shí)現(xiàn)對(duì)私有成員的訪問(wèn)。

            上例只對(duì)私有數(shù)據(jù)成員進(jìn)行了驗(yàn)證,有興趣的可以試試看用函數(shù)指針能否訪問(wèn)私有成員函數(shù)。

            posted on 2008-08-10 14:06 iwong 閱讀(2757) 評(píng)論(4)  編輯 收藏 引用

            評(píng)論

            # re: 通過(guò)指針訪問(wèn)類的私有數(shù)據(jù)成員  回復(fù)  更多評(píng)論   

            夠狠。
            2008-08-10 14:50 | AlexEric

            # re: 通過(guò)指針訪問(wèn)類的私有數(shù)據(jù)成員  回復(fù)  更多評(píng)論   

            不過(guò),我再添點(diǎn)東西,你這個(gè)結(jié)論就得改改了。

            5 class A
            6 {
            7 private:
            8 // a & b are private members of class A
            9 int a;
            10 double b;
            11 public:
            12 // initialize a & b as value 0
            13 A() : a(0), b(0) {}
            14
            15 public:
            16 // for display the value of a & b
            17 int GetA();
            18 double GetB();

            //new function
            virtual int f(){return 0;}
            19 };
            2008-08-10 15:01 | AlexEric

            # re: 通過(guò)指針訪問(wèn)類的私有數(shù)據(jù)成員  回復(fù)  更多評(píng)論   

            再說(shuō),你這個(gè)不完全是指針的強(qiáng)大,也是類型強(qiáng)制轉(zhuǎn)換的結(jié)果。。。
            2008-08-10 15:11 | AlexEric

            # re: 通過(guò)指針訪問(wèn)類的私有數(shù)據(jù)成員[未登錄](méi)  回復(fù)  更多評(píng)論   

            其實(shí)這不過(guò)就是根據(jù)地址修改該地址存儲(chǔ)數(shù)據(jù)的值而已,值得大驚小怪么?知道存儲(chǔ)地址了要修改還不是。。。。。。
            2008-08-11 11:40 | dd

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久久久久无码国产精品中文字幕| 99久久国产免费福利| 久久综合成人网| 久久国产AVJUST麻豆| 久久精品中文字幕一区| 亚洲日韩中文无码久久| 69SEX久久精品国产麻豆| 久久精品国产半推半就| 久久久WWW成人免费精品| 色妞色综合久久夜夜| 青青青国产精品国产精品久久久久| 理论片午午伦夜理片久久| 亚洲AV无码久久精品成人| 精品九九久久国内精品| 国内精品久久久久影院老司| 精品久久久久久综合日本| 国内精品久久国产| 漂亮人妻被中出中文字幕久久| 久久久久AV综合网成人 | 国产精品久久久久久影院| 精品国产乱码久久久久久浪潮| 久久久WWW成人免费毛片| 久久久久久夜精品精品免费啦| 久久久久一级精品亚洲国产成人综合AV区| 中文字幕久久久久人妻| 99久久精品国产一区二区蜜芽| 亚洲人成网亚洲欧洲无码久久| 久久国产综合精品五月天| 久久久久久狠狠丁香| 久久99久国产麻精品66| 欧美成人免费观看久久| 精品久久久久久久久久久久久久久| 久久亚洲欧美国产精品| av色综合久久天堂av色综合在 | 亚洲精品97久久中文字幕无码| 久久婷婷国产麻豆91天堂| 无码专区久久综合久中文字幕| 久久亚洲精品国产亚洲老地址 | 久久精品国产99久久久古代| 蜜臀久久99精品久久久久久| 国产午夜精品理论片久久|