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

            專注于c++

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              21 Posts :: 0 Stories :: 4 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(15)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             

            1、為什么會產生數據對齊問題

                  8CPU 當然不會產生數據對齊問題,當CPU發展到1632位時,因CPU的一次內存訪問就能取回4byte(且用32位舉例,這個數據理所當然的緩存在相應的32位寄存器中)——里面可能存儲了41byte的數據,也可能存儲了22byte的數據……,所以CPU在邏輯上將內存單元尋址地址邊界設置為4的倍數(如:04812……),這是數據對齊產生的必要條件之一;另一個原因是程序中使用的數據類型并非都是4的倍數,如:char1byte),short2byte),int4byte)等等。讓我們考慮一下一個2byte的的變量在內存單元中排布吧:如果這個變量地址為012,那么CPU一次內存訪問就能夠取得你的變量;但如果是3的話,很不幸,CPU還得訪問一次內存以取得全部數據。

                   2、舉例說明

            struct A {
                
            char m_ch;     //1 Byte
                char *m_pStr;  //4 Byte
            };                 //sizeof(A)=8,
            4對齊

            struct B {
                
            char m_ch;     //1 Byte
                int m_count;   //4 Byte  
            };                 //sizeof(A)=8,4對齊

            struct C {
                
            bool m_ok;     //1 Byte
                char m_name[6];//char 也是 1 Byte,6char罷了
            };

            ________________________________________結構體成員________________________________ 

            struct X
            {
                
            double m_width;      //8 Byte
                char   m_name[6];    //1 Byte per
            };                       //sizeof(X)=16

            struct Y {
                
            int m_no;            //4 Byte
                X   m_x;             //X
            8對齊,故按8對齊,
            };                       //sizeof(Y)=8x3=24,提示可將X m_x擴展成struct X

             

            struct X2
            {
                
            double m_width;      //8 Byte
                char   m_name[9];    //1 Byte per,
            8字節+8字節中的一個字節
            };                       //sizeof(X2)=8+8+8=24

             

            struct X2
            {
                
            double m_width;      //8 Byte      8x1
                char   m_name[9];    //
            占用8+8     8x2 8x3
            };                      

            struct Y2 {
                
            int m_no;             //4 Byte,占用另一個8字節 8x4
                X2   m_x;             
            };                       
            //sizeof(Y2)=8+8+8+8=32

            enum DataType {IntData,CharData,VcharData};
            struct Item    
            {
                 
            char ItemNAme[30];  //
            4對齊,故是32
                 DataType ItemType;  //enum4個字節
                 char ItemDecr[50];  //4對齊,所以是52
                 int ItemLength;     //4字節
            };

            sizeof(Item) = 32+4+52+4=92

             

            #pragma pack(2) //指定對齊方式是2
            enum DataType {IntData,CharData,VcharData};

            struct Item    
            {
                
            char ItemNAme[30];  //30
                DataType ItemType;  //4
                char ItemDecr[50];  //50
                int ItemLength;     //4
            };

            sizeof(Item) = 30+4+50+4=88

            posted on 2009-09-30 16:17 bellgrade 閱讀(404) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            亚洲国产精品综合久久网络| 国产精品无码久久四虎| 亚洲精品美女久久久久99小说 | 久久亚洲国产精品一区二区| 久久777国产线看观看精品| 久久久精品视频免费观看| 日韩人妻无码一区二区三区久久99 | 精品多毛少妇人妻AV免费久久| 精品熟女少妇av免费久久| 久久久久国产精品三级网| 亚洲色欲久久久综合网| 久久久久国产一区二区三区| 浪潮AV色综合久久天堂| 久久精品亚洲男人的天堂| 色婷婷综合久久久久中文一区二区| 91精品观看91久久久久久| 亚洲欧美日韩久久精品第一区| 国产精品va久久久久久久| 无码久久精品国产亚洲Av影片| 亚洲国产婷婷香蕉久久久久久 | 人妻无码精品久久亚瑟影视| 久久精品国产亚洲av麻豆小说| 日韩十八禁一区二区久久| A级毛片无码久久精品免费| 国产午夜精品久久久久免费视| 大香伊人久久精品一区二区| 久久艹国产| 久久影院午夜理论片无码| 久久综合久久久| 91精品国产综合久久香蕉 | 国产一区二区精品久久凹凸| 久久99精品久久只有精品| 亚洲国产精品无码久久久秋霞2 | 国产毛片久久久久久国产毛片| 久久久免费精品re6| 久久偷看各类wc女厕嘘嘘| 亚洲va国产va天堂va久久| 亚洲国产精品久久久天堂| 久久久久久亚洲Av无码精品专口 | 国产激情久久久久久熟女老人| 久久天天躁狠狠躁夜夜av浪潮 |