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

            zhgw01

            內(nèi)存對齊,little endian 和big endian

            在筆試中考到,雖然認識到是內(nèi)存對齊的問題,最后還是做錯了,另外下面采用了big endian,一般的都是采用little endian

            class Test
            {
            public
             
            short int a;
             
            int b;
             
            char c[5];
            public:
             Test():b(0x
            1234),a(b){
              c[
            0]='h';
              c[
            1]='e';
              c[
            2]='l';
              c[
            3]='l';
              c[
            4]='o'//我是絕對這里應(yīng)該賦值為'\0'
            }

            }


            int main()
            {
              Test t;
              cout
            <<a<<endl;
              cout
            <<b<<endl;
              cout
            <<sizeof(t)<<endl;
              
            char* p=(char*)&t;
              cout
            <<*(p+8)<<endl;
            }

            sizeof 那里考的就是內(nèi)存對齊的問題,short int 的變量必須從模2為0的開始,int必須從模4為0 的開始,char必須從模1為0的開始,而整個Test依照它的成員中最大的,這里就是int,也就是Test的必須從模4為0的開始,而且它必須占4的倍數(shù)。
            為了滿足int的條件,short int后要填充(padding)兩個字節(jié),為了滿足Test的條件,char[5]后必須填充3個字節(jié),所以總共是2+2+4+5+3=16個字節(jié)
            具體的內(nèi)存對齊可以參考如下
            英文:http://www.chinaitpower.com/2005September/2005-09-13/206312.html
            中文:http://blog.ednchina.com/jasony/92132/Message.aspx
            這樣*(p+8)也就很容易了解了,跳過前面8個字節(jié),即short int 的2個,填充的2個,以及int的4個,最后跳到了c[0]

            little endian 和 big endian

            當一個變量占多個字節(jié)時,如何排列這些字節(jié)就產(chǎn)生出了little endian和big endian的區(qū)別
            little endian: 把低字節(jié)放在內(nèi)存的低位 (The most significant byte is on the right end of a word)
            big endian: 把低字節(jié)放在內(nèi)存的高位 (The most significant byte is on the left end of a word)
            舉個例子:
                 假設(shè)從地址0x00000000開始的一個字中保存有數(shù)據(jù)0x1234abcd,那么在兩種不同的內(nèi)存順序的機器上從字節(jié)的角度去看的話分別表示為:
                   1)little endian:在內(nèi)存中的存放順序是0x00000000-0xcd,0x00000001-0xab,0x00000002-0x34,0x00000003-0x12
                   2)big  endian:在內(nèi)存中的存放順序是0x00000000-0x12,0x00000001-0x34,0x00000002-0xab,0x00000003-0xcd


            在構(gòu)造函數(shù)中的Test():b(0x1234),a(b)看起來有問題,本來想這應(yīng)該涉及到little endian和big endian的問題,不過在vs2005里調(diào)試了一下,發(fā)現(xiàn)由于a比b先聲明,所以實際上時a先初始化,也就是a(b)這個語句先運行,由于這時候b還沒初始化,a的值就是一個隨機數(shù)(相對于不同的運行來說),接著b再初始化為正確值,但是這時候已經(jīng)無法改變a的值了

            posted on 2008-10-27 17:17 apacs 閱讀(579) 評論(0)  編輯 收藏 引用 所屬分類: c++

            My Links

            Blog Stats

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品伊人久久久久AV影院| 久久久久久综合一区中文字幕| 久久精品视频91| 欧美久久综合九色综合| 久久久久久久久66精品片| 日韩精品久久久久久久电影蜜臀| 国产精品久久午夜夜伦鲁鲁| 精品国产综合区久久久久久 | 色诱久久久久综合网ywww | 久久久久亚洲AV无码专区首JN| 亚洲国产精品18久久久久久| 国产成人精品久久亚洲高清不卡 | 久久久久国产精品人妻| 人人狠狠综合久久亚洲婷婷| 国产精品亚洲综合久久| 久久不见久久见免费视频7| 欧美日韩精品久久久久| 国产产无码乱码精品久久鸭| 亚洲国产香蕉人人爽成AV片久久| 久久精品国产精品亚洲精品| 亚洲伊人久久精品影院| 久久精品无码一区二区三区日韩| 久久综合给久久狠狠97色| 欧美亚洲日本久久精品| 狠狠精品久久久无码中文字幕 | 99久久成人国产精品免费| 欧美午夜A∨大片久久 | 日韩精品无码久久一区二区三| 狠狠色丁香久久婷婷综合五月 | 国产精品99精品久久免费| 久久人妻无码中文字幕| 亚洲人成无码www久久久| 国产精品99久久久久久猫咪| 久久久久综合网久久| 2020久久精品国产免费| 国内精品人妻无码久久久影院| 久久SE精品一区二区| 久久午夜夜伦鲁鲁片免费无码影视 | 97精品伊人久久大香线蕉| 亚州日韩精品专区久久久| 99久久人人爽亚洲精品美女|