成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

如何使用C語言的#pragmapack(n)來設(shè)定字節(jié)對齊-創(chuàng)新互聯(lián)

本篇文章為大家展示了如何使用C語言的#pragma pack(n)來設(shè)定字節(jié)對齊,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比迎澤網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式迎澤網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋迎澤地區(qū)。費用合理售后完善,10多年實體公司更值得信賴。

#pragma pack(n)

這是給編譯器用的參數(shù)設(shè)置,有關(guān)結(jié)構(gòu)體字節(jié)對齊方式設(shè)置, #pragma pack是指定數(shù)據(jù)在內(nèi)存中的對齊方式。

#pragma pack (n)             作用:C編譯器將按照n個字節(jié)對齊。
#pragma pack ()               作用:取消自定義字節(jié)對齊方式。

#pragma  pack (push,1)     作用:是指把原來對齊方式設(shè)置壓棧,并設(shè)新的對齊方式設(shè)置為一個字節(jié)對齊

#pragma pack(pop)            作用:恢復(fù)對齊狀態(tài)

因此可見,加入push和pop可以使對齊恢復(fù)到原來狀態(tài),而不是編譯器默認(rèn),可以說后者更優(yōu),但是很多時候兩者差別不大

如:

#pragma pack(push) //保存對齊狀態(tài)

#pragma pack(4)//設(shè)定為4字節(jié)對齊

相當(dāng)于 #pragma  pack (push,4)

解釋一:

每個特定平臺上的編譯器都有自己的默認(rèn)“對齊系數(shù)”(也叫對齊模數(shù))。程序員可以通過預(yù)編譯命令#pragma pack(n),n=1,2,4,8,16來改變這一系數(shù),其中的n就是你要指定的“對齊系數(shù)”。

規(guī)則:

1、數(shù)據(jù)成員對齊規(guī)則:結(jié)構(gòu)(struct)(或聯(lián)合(union))的數(shù)據(jù)成員,第一個數(shù)據(jù)成員放在offset為0的地方,以后每個數(shù)據(jù)成員的對齊按照#pragma pack指定的數(shù)值和這個數(shù)據(jù)成員自身長度中,比較小的那個進行。

2、結(jié)構(gòu)(或聯(lián)合)的整體對齊規(guī)則:在數(shù)據(jù)成員完成各自對齊之后,結(jié)構(gòu)(或聯(lián)合)本身也要進行對齊,對齊將按照#pragma pack指定的數(shù)值和結(jié)構(gòu)(或聯(lián)合)大數(shù)據(jù)成員長度中,比較小的那個進行。

解釋二:

n 字節(jié)的對齊方式 VC 對結(jié)構(gòu)的存儲的特殊處理確實提高 CPU 存儲變量的速度,但是有時候也帶來 了一些麻煩,我們也屏蔽掉變量默認(rèn)的對齊方式,自己可以設(shè)定變量的對齊方式。 VC 中提供了#pragma pack(n)來設(shè)定變量以 n 字節(jié)對齊方式。n 字節(jié)對齊就是說 變量存放的起始地址的偏移量有兩種情況:

第一、如果 n 大于等于該變量所占用的字 節(jié)數(shù),那么偏移量必須滿足默認(rèn)的對齊方式。

第二、如果 n 小于該變量的類型所占用 的字節(jié)數(shù),那么偏移量為 n 的倍數(shù),不用滿足默認(rèn)的對齊方式。結(jié)構(gòu)的總大小也有個 約束條件,分下面兩種情況:如果 n 大于所有成員變量類型所占用的字節(jié)數(shù),那么結(jié) 構(gòu)的總大小必須為占用空間大的變量占用的空間數(shù)的倍數(shù); 否則必須為 n 的倍數(shù)。

下面舉例說明其用法。 #pragma pack(push) //保存對齊狀態(tài)

#pragma pack(4)//設(shè)定為 4 字節(jié)對齊

struct test { char m1; double m4; int m3; }; #pragma pack(pop)//恢復(fù)對齊狀態(tài) 以上結(jié)構(gòu)體的大小為 16:

下面分析其存儲情況,首先為 m1 分配空間,其偏移量 為 0,滿足我們自己設(shè)定的對齊方式(4 字節(jié)對齊),m1 大小為 1 個字節(jié)。接著開始 為 m4 分配空間,這時其偏移量為 1,需要補足 3 個字節(jié),這樣使偏移量滿足為 n=4 的倍數(shù)(因為 sizeof(double)大于 4),m4 占用 8 個字節(jié)。接著為 m3 分配空間,這時 其偏移量為 12,滿足為 4 的倍數(shù),m3 占用 4 個字節(jié)。這時已經(jīng)為所有成員變量分配 了空間,共分配了 16 個字節(jié),滿足為 n 的倍數(shù)。如果把上面的#pragma pack(4)改為 #pragma pack(8),那么我們可以得到結(jié)構(gòu)的大小為 24。

大家看了這些文字描述頭也一定會發(fā)麻吧,我堅持讀完后,然后自己編寫了一個程序:

#pragma pack(4)

struct node{

 int e;
 char f;
 short int a;
 char b;

};

struct node n;

printf("%d\n",sizeof(n));

我自己算的結(jié)果是16,結(jié)果實際結(jié)果是:

12

然后結(jié)構(gòu)體內(nèi)部數(shù)據(jù)成員變動一下位置:

#pragma pack(4)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

12

將對齊位數(shù)強制定位2

#pragma pack(2)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

10

將對齊位數(shù)強制定位1

#pragma pack(1)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

8

看著輸出結(jié)果和文字描述有點暈,下面簡單說一下俺的判定規(guī)則吧:

其實之所以有內(nèi)存字節(jié)對齊機制,就是為了大限度的減少內(nèi)存讀取次數(shù)。我們知道CPU讀取速度比內(nèi)存讀取速度快至少一個數(shù)量級,所以為了節(jié)省運算花費時間,只能以犧牲空間來換取時間了。

下面舉例說明如何大限度的減少讀取次數(shù)。

#pragma pack(1)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

這里強制按照1字節(jié)進行對齊,可以理解成所有的內(nèi)容都是按照1字節(jié)進行讀?。〞呵疫@樣理解,因為這樣可以很好的理解內(nèi)存對其機制),其他所有的數(shù)據(jù)成員都是1字節(jié)的整數(shù)倍,所以也就不用進行內(nèi)存對其,各個成員在內(nèi)存中就按照實際順序進行排列,結(jié)構(gòu)體實際長度為8

#pragma pack(2)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

這里強制按照2字節(jié)進行對齊。如果內(nèi)存分布仍然是連續(xù)的話,那么int e就得三次才能讀到CPU中,所以為了“講究”int e的讀取,所以在char f之后預(yù)留1BYTE,最后的char b也是如此,所以長度為10

#pragma pack(4)

struct node{

 char f;
 int e;
 short int a;
 char b;};

struct node n;

printf("%d\n",sizeof(n));

這里強制按照4字節(jié)進行對齊。所以char f后要預(yù)留3BYTE,而short int a 和 char b可以一次讀取到CPU(按照4字節(jié)讀取),所以長度為12

如果#pramga pack(n)中的n大于結(jié)構(gòu)體成員中任何一個成員所占用的字節(jié)數(shù),則該n值無效。編譯器會選取結(jié)構(gòu)體中大數(shù)據(jù)成員的字節(jié)數(shù)為基準(zhǔn)進行對其

上述內(nèi)容就是如何使用C語言的#pragma pack(n)來設(shè)定字節(jié)對齊,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站jinyejixie.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁名稱:如何使用C語言的#pragmapack(n)來設(shè)定字節(jié)對齊-創(chuàng)新互聯(lián)
網(wǎng)頁路徑:http://jinyejixie.com/article24/coejje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、外貿(mào)建站、網(wǎng)站排名、建站公司、企業(yè)建站、商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
茶陵县| 黄石市| 西充县| 仙桃市| 长岭县| 泰顺县| 万安县| 深圳市| 九寨沟县| 南和县| 武平县| 永安市| 柳林县| 北辰区| 墨江| 宁国市| 岢岚县| 观塘区| 拜城县| 金乡县| 杭州市| 渭源县| 泰兴市| 白河县| 资溪县| 天全县| 临西县| 莲花县| 堆龙德庆县| 固始县| 澎湖县| 南丰县| 大英县| 柏乡县| 泊头市| 兰西县| 全南县| 宁德市| 呼伦贝尔市| 武穴市| 闽侯县|