|
|||||||||||
| 技術(shù)交流 | 電路欣賞 | 工控天地 | 數(shù)字廣電 | 通信技術(shù) | 電源技術(shù) | 測控之家 | EMC技術(shù) | ARM技術(shù) | EDA技術(shù) | PCB技術(shù) | 嵌入式系統(tǒng) 驅(qū)動編程 | 集成電路 | 器件替換 | 模擬技術(shù) | 新手園地 | 單 片 機 | DSP技術(shù) | MCU技術(shù) | IC 設(shè)計 | IC 產(chǎn)業(yè) | CAN-bus/DeviceNe |
32位cpu在默認(rèn)情況下,字節(jié)變量是四字節(jié)對齊的,還是不對齊的? |
| 作者:wjhtinger 欄目:嵌入式系統(tǒng) |
這個有什么決定?編譯器還是硬件?? 明白的給說說。 |
| 2樓: | >>參與討論 |
| 作者: 平常人 于 2006/7/27 18:56:00 發(fā)布:
32位CPU在默認(rèn)情況下,字節(jié)變量不一定是四字節(jié)對齊的 這由編譯器決定。 |
|
| 3樓: | >>參與討論 |
| 作者: wjhtinger 于 2006/7/27 19:05:00 發(fā)布:
.. 但是如果不默認(rèn)對齊的話,單字節(jié)和四字節(jié)地址相互轉(zhuǎn)化就可能出現(xiàn)問題。 但實際開發(fā)中,我們一般并沒有考慮這方面問題,那如果默認(rèn)不對齊豈不是容易出問題了?? |
|
| 4樓: | >>參與討論 |
| 作者: rockos 于 2006/7/28 10:24:00 發(fā)布:
re 簡單測試一下就很清楚了: struct A { SHORT a; /* 可以換成CHAR, SHORT, int, LONG LONG之類的*/ CHAR b; CHAR c; }; int main() { struct A s; printf ("element b offset: %d\n", (int)((CHAR *)&s.b - (CHAR *)&s)); return 0; } 一般來說, CHAR和unsigned CHAR類型的字段不影響結(jié)構(gòu)對齊. 但是遇到SHORT, int時, 編譯器可能會對結(jié)構(gòu)中的某些字段進行對齊(除非指定禁止對齊), 目的是為了加快程序執(zhí)行速度, 因為CPU在處理非對齊數(shù)據(jù)時花消耗更多的指令周期. 被對齊的字段不會是CHAR和unsigned CHAR類型的, 只可能是多字節(jié)類型數(shù)據(jù). |
|
| 5樓: | >>參與討論 |
| 作者: mxh0506 于 2006/7/28 22:55:00 發(fā)布:
編譯器手冊里有說明的 |
|
|
|
| 免費注冊為維庫電子開發(fā)網(wǎng)會員,參與電子工程師社區(qū)討論,點此進入 |
Copyright © 1998-2006 m.58mhw.cn 浙ICP證030469號 |