byte数组存的是什么_结构体内存对齐是什么鬼?
前言
上章節(jié)講解C語言中的聯(lián)合體,位段,以及枚舉類型,不清楚的可以回顧上一章節(jié),本章節(jié)主要針對結(jié)構(gòu)體內(nèi)存占用給大家詳細介紹。
內(nèi)存問題
在編寫C語言以下程序的時候:
struct data
{
????int iNum;
????float fNum;
????long lNum;
};結(jié)構(gòu)體里會包括int char double,它們要占用的空間不同,系統(tǒng)為一個結(jié)構(gòu)體開辟內(nèi)存空間時,會有2種選擇。
第一種:節(jié)省空間的方案,以上面的例子來說的話,就是4(int) + 1(char) + 8(double) =13個字節(jié);
第二種:浪費空間的方案,以上面的例子來說的話,就是4(int) + 4(char) + 8(double) =16個字節(jié);
其實,系統(tǒng)使用的第二種方案,通過sizeof統(tǒng)計檢驗測試結(jié)果如下圖:
為什么存在內(nèi)存對齊
為了CPU只尋找地址一次,就能夠把目標內(nèi)存中的數(shù)據(jù)取出來。計算機中內(nèi)存空間都是按照byte劃分的 ,如果是用第一種節(jié)省空間的方案,為了要取一個int或者double的成員的值,CPU尋址一次,可能只取出來一部分,所以需要再次尋址,這樣就導(dǎo)致CPU的效率降低。為了提高CPU的效率,所以選擇犧牲空間,但是節(jié)省了時間。
ps:?大家在聲明結(jié)構(gòu)體成員的時候,一定把占用空間最小的類型放在最前面,占用空間最大的放在最后面,這樣就會節(jié)省內(nèi)存空間。尤其是在做網(wǎng)絡(luò)數(shù)據(jù)傳輸?shù)臅r候,這樣更能體現(xiàn)其效率性。這樣避免因為對齊問題而導(dǎo)致的無用內(nèi)存的傳輸。
對齊案例分析
最長字節(jié)中間位置分析按照大小順序?qū)懛ê瑪?shù)組的內(nèi)存分析ps:不管數(shù)組里多少個元素,只看數(shù)組的類型,以下面最長字節(jié)去對齊即可
特殊情況
強制對齊:?#pragma pack(4)和上面比較,如果注釋掉?#pragma pack(4),是按照8個字節(jié)去對齊,字節(jié)占用是24個字節(jié)
位段ps:位段中如果存在int類型的本質(zhì)也是以4個字節(jié)去對齊的,注意哦!
尾言
作業(yè):自己寫個結(jié)構(gòu)體,去猜測檢驗學(xué)習(xí)成果,推斷是否和編譯器執(zhí)行結(jié)果一樣
好了今天的知識到這里就結(jié)束了!如果有學(xué)到知識的同學(xué)們,可以留言學(xué)到了哦!如果可以的話也是可以一鍵三連,關(guān)注加轉(zhuǎn)發(fā)和點贊。
總結(jié)
以上是生活随笔為你收集整理的byte数组存的是什么_结构体内存对齐是什么鬼?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 调用wasm_PDX Utopia区块链
- 下一篇: Freeswitch配置之sofia