標(biāo)題: ARM內(nèi)存邊界對齊以及sizeof問題 [打印本頁]

作者: hongniu    時間: 2015-6-26 18:04
標(biāo)題: ARM內(nèi)存邊界對齊以及sizeof問題
默認(rèn)情況下,在32位cpu里,gcc對于結(jié)構(gòu)體的對齊方式是按照四個字節(jié)來對齊的?匆韵陆Y(jié)構(gòu)體


  typedef struct pack{

  char a;

  int b;

  short c;

  }pack;

  對于Pack結(jié)構(gòu)體,默認(rèn)情況下在arm/386平臺下(別的平臺沒試過)sizeof(pack)=12,求解過程如下:

  sizeof(char)=1;

  下一個int b,由于是四個字節(jié),要求b的開始地址從32的整數(shù)倍開始,故需要在a后面填充3個沒用的字節(jié),記為dump(3),sizeof(b)=4,此時相當(dāng)于結(jié)構(gòu)體擴(kuò)充為

  char a;

  char dump(3);

  int b;

  看short c,現(xiàn)在c的前面有8個字節(jié),c是兩個字節(jié),c的開始地址是從16的整數(shù)開始,在b前面不需再加?xùn)|西.此時對于結(jié)構(gòu)體來說,sizeof(pack)=10,但是這不是最終結(jié)果,最后總的字節(jié)數(shù)也要能被4個字節(jié)整除,所以還需在short c后面再加

  dump(2);

  故總的字節(jié)數(shù)為12.

  當(dāng)然以上說的只是簡單的情況,下面談?wù)刟rm,x86在gcc里關(guān)于內(nèi)存邊界字節(jié)對齊的區(qū)別.對于同樣的結(jié)構(gòu)體,在386下

  #prama pack(1)

  后,sizeof(pack)=1 4 2=7

  而在arm下同樣的操作sizeof(pack)=1 4 2 1=8,即雖然b根a之間不要填充但總的長度必須要是4的整數(shù)倍.

  在arm 下要使結(jié)構(gòu)體按指定字節(jié)對齊,可行的方法

  1.在makefile里加-fpack-struct 選項(xiàng),這樣的話對所有的結(jié)構(gòu)按一字節(jié)對齊.

  不得不說,確實(shí)有那么些質(zhì)量較差的程序可能需要你部分自然對齊,部分一字 節(jié)對齊,此時

  2. typedef struct pack{

  }__attribute__((packed))

  可利用__attribute__屬性

  當(dāng)然最后的方式,還是自己去看arm體系結(jié)構(gòu)與gcc編譯選項(xiàng)了。



作者: wlfei22    時間: 2015-10-26 23:11
學(xué)到了




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1