c中的union的用法和作用

2021-06-26 18:04:08 字數 2651 閱讀 1506

在c/c++程式的編寫中,當多個基本資料型別或復合資料結構要占用同一片記憶體時,我們要使用聯合體;當多種型別,多個物件,多個事物只取其一時(我們姑且通俗地稱其為「n 選1」),我們也

可以使用聯合體來發揮其長處。首先看一段**:

union myun

u;int k;

}a;int main()

union型別是共享記憶體的,以size最大的結構作為自己的大小,這樣的話,myun這個結構就包含u這個結構體,而大小也等於u這個結構體 的大小,在記憶體中的排列為宣告的順序x,y,z從低到高,然後賦值的時候,在記憶體中,就是x的位置放置4,y的位置放置5,z的位置放置6,現在對k賦 值,對k的賦值因為是union,要共享記憶體,所以從union的首位址開始放置,首位址開始的位置其實是x的位置,這樣原來記憶體中x的位置就被k所賦的 值代替了,就變為0了,這個時候要進行列印,就直接看記憶體裡就行了,x的位置也就是k的位置是0,而y,z的位置的值沒有改變,所以應該是0,5,6

當程式變成

union myun

u;int k;

int j;

}a;int main()

結果為1,5,6 因為還是從最低的位址開始覆蓋,而不是像有些人想象的是 0,1,6

再看兩個試題:

試題一:編寫一段程式判斷系統中的cpu 是little endian 還是big endian 模式?

分析:作為乙個計算機相關專業的人,我們應該在計算機組成中都學習過什麼叫little endian 和big endian。little endian 和big endian 是cpu 存放資料的兩種不同順序。對於整型、長整型等資料型別,big endian 認為第乙個位元組是最高位位元組(按照從低位址到高位址的順序存放資料的高位位元組到低位位元組);而little endian 則相反,它認為第乙個位元組是最低位位元組(按照從低位址到高位址的順序存放資料的低位位元組到高位位元組)。

0x12 0x34 0xab 0xcd

如果我們去讀取乙個位址為0x0000 的四個位元組變數,若位元組序為big-endian,則讀出結果為0x1234abcd;若位元組序位little-endian,則讀出結果為0xcdab3412。如果我們將0x1234abcd 寫入到以0x0000 開始的記憶體中,則little endian 和big endian 模式的存放結果如下:

位址               0x0000 0x0001 0x0002 0x0003

big-endian         0x12   0x34   0xab   0xcd

little-endian      0xcd   0xab   0x34   0x12

一般來說,x86 系列cpu 都是little-endian 的位元組序,powerpc 通常是big endian,還有的cpu 能通過跳線來設定cpu 工作於little endian 還是big endian 模式。

解答:顯然,解答這個問題的方法只能是將乙個位元組(char/byte 型別)的資料和乙個整型資料存放於同樣的記憶體

開始位址,通過讀取整型資料,分析char/byte 資料在整型資料的高位還是低位來判斷cpu 工作於little

endian 還是big endian 模式。得出如下的答案:

typedef unsigned char byte;

int main(int argc, char* argv)

else //num == 0xff000000

return 0;

}除了上述方法(通過指標型別強制轉換並對整型資料首位元組賦值,判斷該賦值賦給了高位還是低位)外,還有沒

有更好的辦法呢?我們知道,union 的成員本身就被存放在相同的記憶體空間(共享記憶體,正是union 發揮作用、做貢獻的去處),因此,我們可以將乙個char/byte 資料和乙個整型資料同時作為乙個union 的成員,得出

如下答案:

int checkcpu()

c;c.a = 1;

return (c.b == 1);}}

static union endian_test = };

#define endianness ((char)endian_test.mylong)

linux 的核心作者們僅僅用乙個union 變數和乙個簡單的巨集定義就實現了一大段**同樣的功能!由以上一段**我們可以深刻領會到linux 源**的精妙之處!(如果endianness=』l』表示系統為little endian,

為』b』表示big endian )

試題二:假設網路節點a 和網路節點b 中的通訊協議涉及四類報文,報文格式為「報文型別欄位+報文內容的結構體」,四個報文內容的結構體型別分別為structtype1~ structtype4,請編寫程式以最簡單的方式組

織乙個統一的報文資料結構。

分析:報文的格式為「報文型別+報文內容的結構體」,在真實的通訊中,每次只能發四類報文中的一種,我們可以將四類報文的結構體組織為乙個union(共享一段記憶體,但每次有效的只是一種),然後和報文型別字段統一組織成乙個報文資料結構。

解答:根據上述分析,我們很自然地得出如下答案:

typedef unsigned char byte;

//報文內容聯合體

typedef union tagpacketcontent

packetcontent;

//統一的報文資料結構

typedef struct tagpacket

packet;

C中union的用法

union是一種 類似 與struct的聯合體,聯合的所有成員引用的是記憶體中的相同位置,以最大的成員的記憶體長度作為union的記憶體大小。union主要用來節省空間,預設的訪問許可權是公有的.include using namespace std union node t int c obj s...

c中 , , 的作用和用法

c中的括號有著不同的作用和用法,下面我們講一下小口號,中括號,大括號的用法 小括號的用法 1.他最基本的用法是改變運算的優先順序。2.區別函式名和引數,條件表示式中主題和條件的區別。3.c中允許小括號括起來的語句出現在表示式中,一次小括號可以括起來的表示式語 這裡注意賦值語句也是一 個表示式語句,因...

C 中「 」的作用和用法

在看別人程式的時候偶爾看到,總結了一下兩個用途 1.不常用,也不推介用的用法。關鍵字 可以作為識別符號來使用,說白了,就是講關鍵字變成非關鍵字。2.逐字字串字面量,以 開頭,後面是由引導包含的字串。使用引導號暴扣的字串的內容原樣輸出,而且他們能夠跨越兩行或更多行。因此,可以加入新行,製表符等,而不需...