• <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++博客 :: 首頁 :: 聯系 ::  :: 管理
              163 Posts :: 4 Stories :: 350 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(48)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 398977
            • 排名 - 59

            最新評論

            閱讀排行榜

            評論排行榜

            一個很重要的參數
            #pragma pack(n)

            數據邊界對齊方式:
            以如下結構為例: struct {
                                char a;
                                WORD b;
                                DWORD c;
                                char d;
                               }
            在Windows默認結構大小: sizeof(struct) = 4+4+4+4=16;
            與#pragma pack(4)一樣
            若設為 #pragma pack(1), 則結構大小: sizeof(struct) = 1+2+4+1=8;
            若設為 #pragma pack(2), 則結構大小: sizeof(struct) = 2+2+4+2=10;
            在#pragma pack(1)時:空間是節省了,但訪問速度降低了;

            結構體對齊的具體含義(#pragma pack)

            作者:panic 2005年4月2日

            還是來自csdn的帖子:
            主  題:    探討:內存對齊
            作  者:    typedef_chen ((名未定)(我要騙人))
            等  級:   
            信 譽 值:    100
            所屬論壇:    C/C++ C++ 語言
            問題點數:    50
            回復次數:    1
            發表時間:    2005-04-02 22:53:27
              
              
            朋友帖了如下一段代碼:
            #pragma pack(4)
            class TestB
            {
            public:
            int aa;
            char a;
            short b;
            char c;
            };
            int nSize = sizeof(TestB);
            這里nSize結果為12,在預料之中。

            現在去掉第一個成員變量為如下代碼:
            #pragma pack(4)
            class TestC
            {
            public:
            char a;
            short b;
            char c;
            };
            int nSize = sizeof(TestC);
            按照正常的填充方式nSize的結果應該是8,為什么結果顯示nSize為6呢?

            事實上,很多人對#pragma pack的理解是錯誤的。
            #pragma pack規定的對齊長度,實際使用的規則是:
            結構,聯合,或者類的數據成員,第一個放在偏移為0的地方,以后每個數據成員的對齊,按照#pragma pack指定的數值和這個數據成員自身長度中,比較小的那個進行。
            也就是說,當#pragma pack的值等于或超過所有數據成員長度的時候,這個值的大小將不產生任何效果。
            而結構整體的對齊,則按照結構體中最大的數據成員 和 #pragma pack指定值 之間,較小的那個進行。

            具體解釋
            #pragma pack(4)
            class TestB
            {
            public:
            int aa; //第一個成員,放在[0,3]偏移的位置,
            char a; //第二個成員,自身長為1,#pragma pack(4),取小值,也就是1,所以這個成員按一字節對齊,放在偏移[4]的位置。
            short b; //第三個成員,自身長2,#pragma pack(4),取2,按2字節對齊,所以放在偏移[6,7]的位置。
            char c; //第四個,自身長為1,放在[8]的位置。
            };
            這個類實際占據的內存空間是9字節
            類之間的對齊,是按照類內部最大的成員的長度,和#pragma pack規定的值之中較小的一個對齊的。
            所以這個例子中,類之間對齊的長度是min(sizeof(int),4),也就是4。
            9按照4字節圓整的結果是12,所以sizeof(TestB)是12。


            如果
            #pragma pack(2)
                 class TestB
            {
            public:
            int aa; //第一個成員,放在[0,3]偏移的位置,
            char a; //第二個成員,自身長為1,#pragma pack(4),取小值,也就是1,所以這個成員按一字節對齊,放在偏移[4]的位置。
            short b; //第三個成員,自身長2,#pragma pack(4),取2,按2字節對齊,所以放在偏移[6,7]的位置。
            char c; //第四個,自身長為1,放在[8]的位置。
            };
            //可以看出,上面的位置完全沒有變化,只是類之間改為按2字節對齊,9按2圓整的結果是10。
            //所以 sizeof(TestB)是10。

            最后看原貼:
            現在去掉第一個成員變量為如下代碼:
            #pragma pack(4)
            class TestC
            {
            public:
            char a;//第一個成員,放在[0]偏移的位置,
            short b;//第二個成員,自身長2,#pragma pack(4),取2,按2字節對齊,所以放在偏移[2,3]的位置。
            char c;//第三個,自身長為1,放在[4]的位置。
            };
            //整個類的大小是5字節,按照min(sizeof(short),4)字節對齊,也就是2字節對齊,結果是6
            //所以sizeof(TestC)是6。
            posted on 2007-12-23 19:32 sdfasdf 閱讀(10998) 評論(6)  編輯 收藏 引用 所屬分類: C++

            Feedback

            # re: 關于pragma pack的用法(一) 2007-12-23 22:30 修源
            繼續  回復  更多評論
              

            # re: 關于pragma pack的用法(一) 2012-01-13 14:47 ezhong
            開頭怎么是16了。。。差點再次搞糊涂。  回復  更多評論
              

            # re: 關于pragma pack的用法(一)[未登錄] 2012-09-19 10:46 小偉
            經過驗證,樓主講解很透徹。可以把#pragma pack的其他形式為我們講解一下  回復  更多評論
              

            # re: 關于pragma pack的用法(一) 2013-04-03 11:54 誤人子弟
            誤人子弟  回復  更多評論
              

            # re: 關于pragma pack的用法(一) 2013-09-10 09:11 MB
            不懂別亂說,真誤人子弟   回復  更多評論
              

            # re: 關于pragma pack的用法(一) 2014-01-12 12:57 sdafa
            樓主不是一般的水貨啊  回復  更多評論
              

            国产精品99久久久精品无码| 久久成人精品视频| 久久人人爽人人爽人人片AV麻烦| 性高湖久久久久久久久AAAAA| 无码人妻久久一区二区三区蜜桃| 伊人久久大香线蕉综合网站| 国内精品综合久久久40p| 久久久一本精品99久久精品66| 97久久精品无码一区二区| 久久国产午夜精品一区二区三区| 中文字幕热久久久久久久| 久久96国产精品久久久| 久久亚洲中文字幕精品一区四| 久久亚洲中文字幕精品有坂深雪| 久久av高潮av无码av喷吹| 色妞色综合久久夜夜| 久久精品免费大片国产大片| 亚洲精品美女久久久久99| 久久久久久无码国产精品中文字幕| 亚洲午夜久久久影院伊人| 久久99精品国产麻豆蜜芽| 日本人妻丰满熟妇久久久久久| 久久天天躁狠狠躁夜夜2020| 久久精品国产69国产精品亚洲 | 亚洲精品无码久久千人斩| 99久久免费国产精品| 欧美一区二区三区久久综| 亚洲国产成人久久一区WWW| 久久亚洲精品视频| 国产精品美女久久久久| 亚洲精品无码成人片久久| 欧美亚洲国产精品久久久久| 国产香蕉97碰碰久久人人| 99久久国产综合精品成人影院| 久久精品亚洲中文字幕无码麻豆| 综合久久一区二区三区| 一本久道久久综合狠狠躁AV| 亚洲AV伊人久久青青草原| 欧美一级久久久久久久大片 | 97精品伊人久久久大香线蕉| 日本精品一区二区久久久|