• <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>
            ??? 在我們的程序中,數(shù)據(jù)結(jié)構(gòu)還有變量等等都需要占有內(nèi)存,在很多系統(tǒng)中,它都要求內(nèi)存分配的時(shí)候要對齊,這樣做的好處就是可以提高訪問內(nèi)存的速度。


            ?我們還是先來看一段簡單的程序:


            ??????????????????????????????? 程序一
            ?1?#include?<iostream>
            ?2?using?namespace?std;
            ?3?
            ?4?struct?X1
            ?5?{
            ?6???int?i;//4個字節(jié)
            ?7???char?c1;//1個字節(jié)
            ?8???char?c2;//1個字節(jié)
            ?9?};
            10?
            11?struct?X2
            12?{
            13???char?c1;//1個字節(jié)
            14???int?i;//4個字節(jié)
            15???char?c2;//1個字節(jié)
            16?};
            17?
            18?struct?X3
            19?{
            20???char?c1;//1個字節(jié)
            21???char?c2;//1個字節(jié)
            22???int?i;//4個字節(jié)
            23?};
            24?int?main()
            25?{???
            26?????cout<<"long?"<<sizeof(long)<<"\n";
            27?????cout<<"float?"<<sizeof(float)<<"\n";
            28?????cout<<"int?"<<sizeof(int)<<"\n";
            29?????cout<<"char?"<<sizeof(char)<<"\n";
            30?
            31?????X1?x1;
            32?????X2?x2;
            33?????X3?x3;
            34?????cout<<"x1?的大小?"<<sizeof(x1)<<"\n";
            35?????cout<<"x2?的大小?"<<sizeof(x2)<<"\n";
            36?????cout<<"x3?的大小?"<<sizeof(x3)<<"\n";
            37?????return?0;
            38?}

            ??????
            ??????這段程序的功能很簡單,就是定義了三個結(jié)構(gòu)X1,X2,X3,這三個結(jié)構(gòu)的主要區(qū)別就是內(nèi)存數(shù)據(jù)擺放的順序,其他都是一樣的,另外程序輸入了幾種基本類型所占用的字節(jié)數(shù),以及我們這里的三個結(jié)構(gòu)所占用的字節(jié)數(shù)。

            這段程序的運(yùn)行結(jié)果為:

            1?long?4
            2?float?4
            3?int?4
            4?char?1
            5?x1?的大小?8
            6?x2?的大小?12
            7?x3?的大小?8


            ???? 結(jié)果的前面四行沒有什么問題,但是我們在最后三行就可以看到三個結(jié)構(gòu)占用的空間大小不一樣,造成這個原因就是內(nèi)部數(shù)據(jù)的擺放順序,怎么會這樣呢?

            ??? 下面就是我們需要講的內(nèi)存對齊了。

            ??? 內(nèi)存是一個連續(xù)的塊,我們可以用下面的圖來表示,? 它是以4個字節(jié)對一個對齊單位的:

            ??????????????????????????????????????????????????? 圖一

            mem1.jpg

            ?? 讓我們看看三個結(jié)構(gòu)在內(nèi)存中的布局:

            ?? 首先是 X1,如下圖所示

            mem2.jpg


            ????X1 中第一個是 Int類型,它占有4字節(jié),所以前面4格就是滿了,然后第二個是char類型,這中類型只占一個字節(jié),所以它占有了第二個4字節(jié)組塊中的第一格,第三個也是char類型,所以它也占用一個字節(jié),它就排在了第二個組塊的第二格,因?yàn)樗鼈兗釉谝黄鸫笮∫膊怀^一個塊,所以他們?nèi)齻€變量在內(nèi)存中的結(jié)構(gòu)就是這樣的,因?yàn)橛袃?nèi)存分塊對齊,所以最后出來的結(jié)果是8,而不是6,因?yàn)楹竺鎯蓚€格子其實(shí)也算是被用了。

            ??? 再次看看X2,如圖所示

            mem4.jpg

            ????X2中第一個類型是Char類型,它占用一個字節(jié),所以它首先排在第一組塊的第一個格子里面,第二個是Int類型,它占用4個字節(jié),第一組塊已經(jīng)用掉一格,還剩3格,肯定是無法放下第二Int類型的,因?yàn)橐紤]到對齊,所以不得不把它放到第二個組塊,第三個類型是Char類型,跟第一個類似。所因?yàn)橛袃?nèi)存分塊對齊,我們的內(nèi)存就不是8個格子了,而是12個了。


            再看看X3,如下圖所示:



            mem3.jpg

            ???關(guān)于X3的說明其實(shí)跟X1是類似的,只不過它把兩個1個字節(jié)的放到了前面,相信看了前面兩種情況的說明這里也是很容易理解的。

            Posted on 2006-11-29 15:36 艾凡赫 閱讀(281) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久国产成人| 久久久久久午夜成人影院| 国产99久久久久久免费看| 国内精品久久久久久久亚洲| 狠狠综合久久综合中文88| 久久99九九国产免费看小说| 天天爽天天狠久久久综合麻豆| 精品一区二区久久| 久久午夜福利无码1000合集| 国内精品伊人久久久久| 国产一区二区久久久| 99久久这里只有精品| 久久人人爽人人人人片av| 久久亚洲国产精品一区二区| 亚洲色婷婷综合久久| 久久久久久国产a免费观看不卡| 久久久噜噜噜www成人网| 中文字幕精品久久久久人妻| 99久久99久久精品国产片果冻 | 国产成人久久久精品二区三区 | 国产激情久久久久影院老熟女| 久久精品国产99久久久古代| 久久久久成人精品无码| 婷婷综合久久狠狠色99h| 久久久久亚洲AV无码永不| 国产精品99久久久久久宅男小说| 亚洲综合精品香蕉久久网97| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 麻豆亚洲AV永久无码精品久久| 欧美大战日韩91综合一区婷婷久久青草| 久久综合久久自在自线精品自| 久久综合亚洲色HEZYO社区| 久久最新免费视频| 久久午夜福利电影| 99久久国产亚洲高清观看2024| 丁香五月网久久综合| 7777久久亚洲中文字幕| 97久久精品午夜一区二区| 久久久国产精品福利免费| 久久精品免费观看| 国产精品gz久久久|