C語言結(jié)構(gòu)體到底占多少內(nèi)存?莫慌!一文助你解決結(jié)構(gòu)體內(nèi)存問題

前言
本文主要介紹的是C/C++中 結(jié)構(gòu)體的所占用內(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é)果如下圖:

為什么存在字節(jié)對齊?
為了CPU只尋找地址一次,就能夠把目標內(nèi)存中的數(shù)據(jù)取出來。計算機中內(nèi)存空間都是按照byte劃分的 ,如果是用第一種節(jié)省空間的方案,為了要取一個int或者double的成員的值,CPU尋址一次,可能只取出來一部分,所以需要再次尋址,這樣就導致CPU的效率降低。為了提高CPU的效率,所以選擇犧牲空間,但是節(jié)省了時間。
ps:?大家在聲明結(jié)構(gòu)體成員的時候,一定把占用空間最小的類型放在最前面,占用空間最大的放在最后面,這樣就會節(jié)省內(nèi)存空間。尤其是在做網(wǎng)絡(luò)數(shù)據(jù)傳輸?shù)臅r候,這樣更能體現(xiàn)其效率性。這樣避免因為對齊問題而導致的無用內(nèi)存的傳輸。
對齊案例分析
No.1 最長字節(jié)中間位置分析

No.2 按照大小順序?qū)懛?/strong>

No.3 函數(shù)組的內(nèi)存分析

ps:不管數(shù)組里多少個元素,只看數(shù)組的類型,以下面最長字節(jié)去對齊即可
特殊情況
NO.1 強制對齊:?#pragma pack(4)

和上面比較,如果注釋掉?#pragma pack(4),是按照8個字節(jié)去對齊,字節(jié)占用是24個字節(jié)
NO.2 位段

ps:位段中如果存在int類型的本質(zhì)也是以4個字節(jié)去對齊的,注意哦!
好了今天的知識到這里就結(jié)束了!如果有學到知識的同學們,可以留言學到了哦!如果可以的話也是可以一鍵三連,關(guān)注加轉(zhuǎn)發(fā)和點贊。
尾言
文章都是手打原創(chuàng),每天最淺顯的介紹C語言、C++,windows知識,喜歡我的文章就關(guān)注一波吧,每天帶你學習C/C++不同的知識,也可以看到最新更新和之前發(fā)表的文章哦。如果足下基礎(chǔ)比較差,不妨關(guān)注下人人都可以學習的視頻教程通俗易懂,深入淺出,一個視頻只講一個知識點。視頻不深奧,不需要鉆研,在公交、在地鐵、在廁所都可以觀看,隨時隨地漲姿勢