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

            cc

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks
            class?a
            {
            word?m_a1;
            word?m_a2;
            a(){m_a1=1;m_a2=2;}
            void?fun(){printf("%d,%d",m_a1,m_a2);}
            }
            class?b
            {
            dword?m_a3;
            b(){m_a3=3;}
            void?fun(){printf("%d",m_a3);}
            }
            main()
            {
            a?a;
            b?*pb;
            pb=b*(&a);
            pb->fun();
            }
            輸出是什么?
            posted on 2006-12-17 15:30 醒目西西 閱讀(595) 評論(2)  編輯 收藏 引用 所屬分類: 編程相關

            評論

            # re: 一道騰訊的面試題 2006-12-17 15:30 醒目西西
            結果是1
            pb=(b*)(&A); 將A的地址傳給了pb,并強制轉化為b類的地址
            pb->fun(); 調用b 的fun()方法,不過此時ma_3,是a類的ma_1,所以輸出1

            你可以改一下程序運行就知道了
            #include <stdio.h>
            class a
            {
            char m_a1;
            char m_a2;
            public:
            a(){m_a1=1;m_a2=2;}
            void fun(){printf("%d,%d",m_a1,m_a2);}
            };
            class b
            {
            char m_a3;
            public:
            b(){m_a3=3;}
            void fun(){printf("%dggggg",m_a3);}//可以看出是調用了該方法
            };
            void main()
            {
            a A;
            b *pb;
            pb=(b*)(&A);
            pb->fun();
            }   回復  更多評論
              

            # re: 一道騰訊的面試題 2006-12-17 15:30 醒目西西
            在win32和32位編譯器的環境下,結構體(struct和class)中的數據域是按聲明的先后順序,“向上生長”的。就是說若結構體A中按先后聲明了兩個域a、b,則存放b的地址大與存放a的地址!注意,有些編譯器為了提高在32位系統中對內存的訪問速度,所以使用了內存對齊技術--結構體中的各個域是按4字節對齊的!

            我們假設樓主提供的題目如下:
            #include <stdlib.h>
            #include <stdio.h>
            class a {
            short m_a1;
            short m_a2;
            public:
            a() {
            m_a1 = 1;
            m_a2 = 2;
            }
            void fun() {
            printf("%d,%d", m_a1, m_a2);
            }
            };

            class b{
            int m_a3;
            b() {
            m_a3 = 3;
            }
            public:
            void fun() {
            printf("%d", m_a3);
            }
            };

            int main() {
            printf("sizeof a, b = %d %d\n", sizeof(a), sizeof(b));
            a a;
            b *pb;
            pb = (b*)(&a);
            pb -> fun();
            }

            就是說,a的大小是8字節,b的大小是4字節!
            而b::fun()就是按int的格式輸出結構體中的前四個字節!所以輸出1!

            但是,若沒有使用內存對齊技術!上面的問題就麻煩了!
            a和b 的大小都是4字節!

            a a+2
            1 2 -> (2 << 16) | 1

            所以應該輸出:

            131073  回復  更多評論
              

            中文字幕乱码人妻无码久久| 久久发布国产伦子伦精品| 青青青国产精品国产精品久久久久 | 久久久久亚洲av综合波多野结衣| 一本色综合久久| 久久青青草原亚洲av无码app| 91麻精品国产91久久久久| 久久久99精品成人片中文字幕| 性高湖久久久久久久久AAAAA| 区久久AAA片69亚洲| 色综合久久精品中文字幕首页| 亚洲AⅤ优女AV综合久久久| 97久久国产亚洲精品超碰热| 久久综合色区| 中文字幕成人精品久久不卡| 国产精品久久久久久久久软件 | 一本大道久久a久久精品综合| 亚洲国产小视频精品久久久三级| 久久久久亚洲精品无码蜜桃| 欧美精品九九99久久在观看| 2022年国产精品久久久久| 婷婷国产天堂久久综合五月| 热99re久久国超精品首页| 久久久噜噜噜www成人网| 一本一本久久A久久综合精品| 久久久久免费视频| 国产成人精品久久一区二区三区av| 久久久无码精品亚洲日韩蜜臀浪潮 | 久久婷婷激情综合色综合俺也去| 久久涩综合| 亚洲国产精品无码久久久久久曰| 精品久久久久久国产三级| 青草影院天堂男人久久| 久久精品99久久香蕉国产色戒 | 国产成人久久AV免费| 香蕉久久久久久狠狠色| 久久久久久毛片免费看| 久久综合色之久久综合| 综合久久一区二区三区| 久久天天躁狠狠躁夜夜2020一| 久久久久久精品免费免费自慰|