欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談C語言的字節(jié)對齊 #pragma pack(n)2

 更新時間:2017年01月09日 10:42:35   投稿:jingxian  
下面小編就為大家?guī)硪黄獪\談C語言的字節(jié)對齊 #pragma pack(n)2。小編覺得挺不錯的現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

#pragma pack(n)

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

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


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

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

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

如:

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

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

相當于 #pragma  pack (push,4) 

解釋一:

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

規(guī)則:

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

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

解釋二:

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

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

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

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

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

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

下面分析其存儲情況,首先為 m1 分配空間,其偏移量 為 0,滿足我們自己設定的對齊方式(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),那么我們可以得到結構的大小為 24。

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

#pragma pack(4)

struct node{

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

};

struct node n;

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

我自己算的結果是16,結果實際結果是:

12

然后結構體內部數(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

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

其實之所以有內存字節(jié)對齊機制,就是為了最大限度的減少內存讀取次數(shù)。我們知道CPU讀取速度比內存讀取速度快至少一個數(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é)進行對齊,可以理解成所有的內容都是按照1字節(jié)進行讀?。〞呵疫@樣理解,因為這樣可以很好的理解內存對其機制),其他所有的數(shù)據(jù)成員都是1字節(jié)的整數(shù)倍,所以也就不用進行內存對其,各個成員在內存中就按照實際順序進行排列,結構體實際長度為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é)進行對齊。如果內存分布仍然是連續(xù)的話,那么int e就得三次才能讀到CPU中,所以為了“講究”int e的讀取,所以在char f之后預留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后要預留3BYTE,而short int a 和 char b可以一次讀取到CPU(按照4字節(jié)讀取),所以長度為12

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

以上這篇淺談C語言的字節(jié)對齊 #pragma pack(n)2就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • C++實現(xiàn)簡易文本編輯器

    C++實現(xiàn)簡易文本編輯器

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡易文本編輯器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • xxx_cast類型轉換的實現(xiàn)方法

    xxx_cast類型轉換的實現(xiàn)方法

    下面小編就為大家?guī)硪黄獂xx_cast類型轉換的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C語言實現(xiàn)父進程主動終止子進程的方法總結

    C語言實現(xiàn)父進程主動終止子進程的方法總結

    一般的情況,子進程自己運行完后,執(zhí)行exit 或者return 后,父進程wait.  waitpid收回子進程,但子進程是一個循環(huán)等待狀態(tài)不主動退出,父進程可以采用文中介紹的幾種方法,需要的朋友可以參考下
    2023-10-10
  • C語言 用while循環(huán)求和的平均值操作

    C語言 用while循環(huán)求和的平均值操作

    這篇文章主要介紹了C語言 用while循環(huán)求和的平均值操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 詳解C++何時需要拷貝構造函數(shù)

    詳解C++何時需要拷貝構造函數(shù)

    拷貝構造函數(shù)是一個特殊的構造函數(shù),用于創(chuàng)建一個新對象,該對象與另一個同類對象具有相同的屬性和值,在 C++ 中,拷貝構造函數(shù)通常采用另一個同類對象作為參數(shù),并使用該對象初始化新對象,本文給大家講講何時需要拷貝函數(shù),需要的朋友可以參考下
    2023-09-09
  • C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題

    C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題

    Dynamic Programming動態(tài)規(guī)劃方法采用最優(yōu)原則來建立用于計算最優(yōu)解的遞歸式,并且考察每個最優(yōu)決策序列中是否包含一個最優(yōu)子序列,這里我們就來展示C語言使用DP動態(tài)規(guī)劃思想解最大K乘積與乘積最大問題
    2016-06-06
  • C++ pair的基本用法總結整理

    C++ pair的基本用法總結整理

    這篇文章主要介紹了C++ pair的基本用法總結整理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • C 語言基礎教程(一)顏色加亮

    C 語言基礎教程(一)顏色加亮

    C 語言基礎教程(一)顏色加亮...
    2007-02-02
  • C++ namespace案例詳解

    C++ namespace案例詳解

    這篇文章主要介紹了C++ namespace案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • C++中的類型查詢之探索typeid和type_info(推薦)

    C++中的類型查詢之探索typeid和type_info(推薦)

    C++ 是一種靜態(tài)類型語言,這意味著每個變量的類型在編譯時就已經(jīng)確定,在這篇技術分享中,我們將探討 C++ 中的 typeid 和 type_info,以及如何使用它們來獲取類型信息,需要的朋友可以參考下
    2024-05-05

最新評論