青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

攀升·Uranus


Something Different,Something New
數(shù)據(jù)加載中……

結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)

          剛剛完成一個文件的遷移程序,其中遇到了結(jié)構(gòu)體對齊的問題,所以拿出來說說,與各位博友們分享。

我的程序很簡單,就是把之前通過一個結(jié)構(gòu)體fwrite到文件A里的內(nèi)容讀出,然后轉(zhuǎn)給另一個結(jié)構(gòu)體保存。程序是簡單,但我擔(dān)心的是之前結(jié)構(gòu)體fwrite到文件A的程序?qū)R結(jié)構(gòu)體規(guī)則是怎樣的?一定要知道它嗎? 當(dāng)然了,如果那個程序結(jié)構(gòu)體是按照1對齊寫入的,我的程序結(jié)構(gòu)體是按照4對齊讀入,那不就糟了!

      這里我引入結(jié)構(gòu)體對齊的概念,也可以說是內(nèi)存對齊了。為什么要內(nèi)存對齊呢,就是方便CPU尋址了,具體原因大家要參考計算機(jī)體系結(jié)構(gòu)了。先看一個內(nèi)存對齊的例子:

      struct example1{

           char a;

           double b;

           long l;

};

      struct example2{

           char a;

           long l;

           double b;

};

大家算算結(jié)構(gòu)體大小,初次接觸的博友可能對答案有點(diǎn)驚訝,VC編譯, sizeof后結(jié)果分別是:2416 同樣是的結(jié)構(gòu)體,成員換了順序,大小就不同了。其實(shí)內(nèi)存對齊有個規(guī)則,只要知道了,就OK。那么以下5點(diǎn)是關(guān)鍵

1.          內(nèi)存對齊與編譯器設(shè)置有關(guān),首先要搞清編譯器這個默認(rèn)值是多少

2.          如果不想編譯器默認(rèn)的話,可以通過#pragma pack(n)來指定按照n對齊

3.          每個結(jié)構(gòu)體變量對齊,如果對齊參數(shù)n(編譯器默認(rèn)或者通過pragma指定)大于該變量所占字節(jié)數(shù)(m),那么就按照m對齊,內(nèi)存偏移后的地址是m的倍數(shù),否則是按照n對齊,內(nèi)存偏移后的地址是n的倍數(shù)。也就是最小化長度規(guī)則

4.          結(jié)構(gòu)體總大小: 對齊后的長度必須是成員中最大的對齊參數(shù)的整數(shù)倍。最大對齊參數(shù)是從第三步得到的。

5.          補(bǔ)充:如果結(jié)構(gòu)體A中還要結(jié)構(gòu)體B,那么B的對齊方式是選它里面最長的成員的對齊方式

所以計算結(jié)構(gòu)體大小要走三步,首先確定是當(dāng)前程序按照幾對齊(參照12點(diǎn)),接著計算每個結(jié)構(gòu)體變量的大小和偏移(參照35),最后計算結(jié)構(gòu)體總大小(參照4)。

      先算算example1吧,假設(shè)編譯器是以16對齊的

      1.確定按照幾對齊: 16;

      2.確定每個成員的偏移:a 占一個字節(jié),16>1, 按照1對齊,起始位置00%1 = 0,那么a就存在0位置;b8個字節(jié),16>8,按照8對齊,起始位置就不能是1了,因?yàn)橐凑?/span>8對齊,所以最近的偏移起始位置是8 8%8 =0, 那么b就存在位置8-15的位置;l4個字節(jié),16>4,按照4對齊,起始位置16 16%4=0,那么l就存在位置16-19的位置。所以結(jié)構(gòu)體從019一共占用20個字節(jié)

      3.結(jié)構(gòu)體總大小:成員中最大的對齊參數(shù)是b8對齊,所以208!=0, 24剛好。

      真的很搞!同理計算example2應(yīng)該是16

     再舉個結(jié)構(gòu)體嵌套的例子吧,

#pragma pack(push)

#pragma pack(8)

struct test1{

      int a;

      char b;

      int c[20]

long l;

} ;

struct test2{

      char a1;

      char a2;

      struct test1 t1;

      double b1;

}

#pragma pack(pop)

先計算test1, 8對齊,a占用0-3b占用4c占用887l占用8891,一共92個字節(jié)。成員中最大的對齊參數(shù)是int92%4=0;

再計算test2, a1z占用0a2占用1t1呢,4 % 4 (test1里面最長的成員的對齊方式) = 0, 4-95b196103;一共104個字節(jié),成員中最大的對齊參數(shù)是double104%8=0; 所以是104.


      那關(guān)于我文章開頭提到的那個文件轉(zhuǎn)換,我現(xiàn)在只要知道原始程序是按照什么對齊的,然后在新程序中指定按照幾對齊就可以了,哈哈!            
      
      擠時間寫的,
有的地方有遺漏,請各位指正!

posted on 2009-01-06 23:39 攀升 閱讀(8905) 評論(9)  編輯 收藏 引用 所屬分類: C/C++

評論

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

恩. 很有道理
2009-01-07 11:13 | li_young

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

在gcc下example1和example2都是16
2009-01-07 12:53 | ronliu

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

在gcc下example1和example2都是16 中默認(rèn)字節(jié)對齊為4 所以都是16
2009-01-07 16:57 | feosun

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

@ronliu
博友feosun告訴了你答案
所以為了防止不同編譯器對齊不一樣,我建議在代碼里面指定對齊參數(shù)
#pragma pack(n)
2009-01-07 18:14 | 攀升

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

內(nèi)存對齊一直是很熱的話題啊。。呵呵。。。
2009-01-08 08:38 | guest

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

有個地方?jīng)]太看懂
就是嵌套結(jié)構(gòu)體時,如何決定嵌套結(jié)構(gòu)體的首地址?即文中"t1呢,92%2!=0, 2-92"這一段,不是說考慮結(jié)構(gòu)體大小時,應(yīng)該為其成員的最大值么?
2009-08-31 10:54 | 游客

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

能否把我給你的評論(最前面的兩條中有)刪掉,我的留言中使用了郵件地址,收到了無數(shù)的垃圾郵件,煩都煩死了。如果可以,真的不勝感激
2009-10-16 22:09 | 你好!

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

@你好!
我?guī)湍闾幚砹耍?
2010-01-14 23:12 | 攀升

# re: 結(jié)構(gòu)體對齊那點(diǎn)事 熟練c/c++(四)   回復(fù)  更多評論   

@游客
>有個地方?jīng)]太看懂
>就是嵌套結(jié)構(gòu)體時,如何決定嵌套結(jié)構(gòu)體的首地址?即文中"t1呢,92%2!>=0, 2-92"這一段,不是說考慮結(jié)構(gòu)體大小時,應(yīng)該為其成員的最大值么?

謝謝你的提醒,我改好了,呵呵
2010-01-14 23:24 | 攀升
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美成人日韩| 亚洲精品免费网站| 国产精品日韩精品欧美在线| 欧美1区3d| 免费看成人av| 免费看av成人| 欧美日韩亚洲一区二区三区在线观看 | 国产精品乱码妇女bbbb| 欧美午夜精品伦理| 国产欧美精品一区aⅴ影院| 黑人一区二区三区四区五区| 在线播放一区| 亚洲无线一线二线三线区别av| 亚洲资源在线观看| 久久亚洲精品伦理| 亚洲乱码视频| 欧美影院视频| 欧美日韩一区国产| 一色屋精品亚洲香蕉网站| 日韩性生活视频| 一区二区三区视频观看| 亚洲综合欧美日韩| 久久综合久久久久88| 亚洲福利在线观看| 亚洲欧美激情诱惑| 欧美精品日韩一区| 好吊妞**欧美| 亚洲欧美在线另类| 亚洲第一综合天堂另类专| 亚洲一区二区三区激情| 男女精品网站| 韩国免费一区| 欧美亚洲色图校园春色| 亚洲国产欧美在线人成| 欧美一区二区私人影院日本 | 欧美亚洲一级| 亚洲另类视频| 欧美~级网站不卡| 国产亚洲激情视频在线| 宅男噜噜噜66一区二区| 免费毛片一区二区三区久久久| 一区二区日韩伦理片| 久久影音先锋| 韩国三级在线一区| 久久国产精品久久久久久久久久 | 亚洲视频高清| 亚洲欧洲三级| 欧美高清一区| 亚洲韩国日本中文字幕| 久热成人在线视频| 午夜视频一区在线观看| 国产精品女同互慰在线看| 在线视频一区观看| 91久久精品一区| 欧美国产日韩在线| 日韩一级在线观看| 亚洲日本aⅴ片在线观看香蕉| 久热精品视频在线观看一区| 精品不卡一区| 欧美黄在线观看| 女仆av观看一区| 日韩午夜一区| 一区二区三区四区蜜桃| 欧美视频中文在线看| 亚洲——在线| 午夜精品免费| 激情久久综艺| 欧美国产一区二区| 欧美精品日韩| 午夜精品视频一区| 欧美中文字幕在线观看| 国产一区日韩欧美| 欧美国产日本高清在线| 欧美成人在线免费视频| 一区二区三区免费网站| 免费在线播放第一区高清av| 在线成人小视频| 亚洲电影在线播放| 欧美日韩激情网| 亚洲一区久久久| 亚洲欧美变态国产另类| 海角社区69精品视频| 欧美激情一区在线| 欧美午夜在线视频| 久久久久久色| 欧美激情亚洲另类| 翔田千里一区二区| 久久天天狠狠| 亚洲综合色在线| 久久亚洲影音av资源网| 中文国产一区| 久久精品二区| 亚洲一区不卡| 久久综合久久综合久久| 亚洲性图久久| 久久久免费观看视频| 9色国产精品| 久久精品视频在线免费观看| 日韩亚洲成人av在线| 午夜精品一区二区三区电影天堂 | 日韩一级在线观看| 午夜亚洲一区| 一区二区三区国产在线观看| 性色av香蕉一区二区| 99re国产精品| 久久久久久一区二区三区| 亚洲调教视频在线观看| 久久青青草综合| 欧美一区二区三区在线观看视频 | 亚欧美中日韩视频| 欧美激情无毛| 老司机久久99久久精品播放免费| 欧美日韩美女| 欧美激情精品久久久久| 国产日韩在线播放| 亚洲一区二区三| 一区二区三区四区五区视频| 理论片一区二区在线| 久久精品国产亚洲aⅴ| 欧美午夜精品电影| 亚洲片区在线| 亚洲精选91| 欧美成人dvd在线视频| 猛干欧美女孩| 在线观看国产日韩| 久久精品首页| 久久先锋资源| 黑人巨大精品欧美黑白配亚洲| 国产精品老牛| 欧美午夜电影在线观看| 久久久夜精品| 国产精品卡一卡二| 一本久道久久综合狠狠爱| 最新国产乱人伦偷精品免费网站| 亚洲影视在线| 欧美一区二区三区四区在线观看| 欧美三级视频在线| 亚洲精品偷拍| 中文在线资源观看网站视频免费不卡| 欧美sm极限捆绑bd| 亚洲国产婷婷| 夜夜嗨av一区二区三区网站四季av| 久热爱精品视频线路一| 欧美成人久久| 亚洲日本欧美在线| 欧美国产综合一区二区| 亚洲国产一区二区a毛片| 亚洲精品乱码| 欧美日韩一区二区精品| 亚洲婷婷综合色高清在线| 午夜激情综合网| 国产婷婷一区二区| 久久亚洲一区二区| 亚洲激情影视| 亚洲一区视频| 国产一区二区欧美| 玖玖国产精品视频| 日韩视频在线一区二区| 午夜精品久久久久久久99水蜜桃| 国产人成精品一区二区三| 久久成人av少妇免费| 欧美成人午夜激情在线| 99热免费精品在线观看| 国产精品日韩| 久热精品在线| 亚洲一区中文| 免费美女久久99| 亚洲视频在线观看视频| 国产日韩综合| 欧美精品videossex性护士| 亚洲一区视频在线| 欧美大片在线看| 欧美一区二区免费观在线| 亚洲国产经典视频| 欧美性大战久久久久久久蜜臀| 欧美一区亚洲一区| 99av国产精品欲麻豆| 久久婷婷亚洲| 亚洲综合欧美| 亚洲日本电影在线| 国产色产综合色产在线视频| 欧美国产日产韩国视频| 久久9热精品视频| 亚洲一区欧美二区| 欧美va天堂| 先锋影院在线亚洲| 91久久精品一区| 国产日韩欧美| 欧美色另类天堂2015| 久久免费国产| 先锋a资源在线看亚洲| 亚洲靠逼com| 欧美电影在线播放| 久久久精彩视频| 亚洲免费婷婷| 夜夜嗨av一区二区三区四区| 亚洲第一福利社区| 韩国三级在线一区| 国产精品制服诱惑| 欧美日韩一区视频|