C语言union关键字
生活随笔
收集整理的這篇文章主要介紹了
C语言union关键字
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
union 關(guān)鍵字的用法與struct 的用法非常類似。
union 維護(hù)足夠的空間來(lái)置放多個(gè)數(shù)據(jù)成員中的“一種”,而不是為每一個(gè)數(shù)據(jù)成員配置空間,在union 中所有的數(shù)據(jù)成員共用一個(gè)空間,同一時(shí)間只能儲(chǔ)存其中一個(gè)數(shù)據(jù)成員,所有的數(shù)據(jù)成員具有相同的起始地址。例子如下:
union StateMachine
{
? ?char character;
? ?int number;
? ?char *str;
? ?double exp;
};
一個(gè)union 只配置一個(gè)足夠大的空間以來(lái)容納最大長(zhǎng)度的數(shù)據(jù)成員,以上例而言,最大長(zhǎng)度是double 型態(tài),所以StateMachine 的空間大小就是double 數(shù)據(jù)類型的大小。
在C++里,union 的成員默認(rèn)屬性頁(yè)為public。union 主要用來(lái)壓縮空間。如果一些數(shù)據(jù)不可能在同一時(shí)間同時(shí)被用到,則可以使用union。
union
{
? ?int i;
? ?char a[2];
}*p, u;
p =&u;
p->a[0] = 0x39;
p->a[1] = 0x38;
p.i 的值應(yīng)該為多少呢?
這里需要考慮存儲(chǔ)模式:大端模式和小端模式。大端模式(Big_endian):字?jǐn)?shù)據(jù)的高字節(jié)存儲(chǔ)在低地址中,而字?jǐn)?shù)據(jù)的低字節(jié)則存放在高地址中。 小端模式(Little_endian):字?jǐn)?shù)據(jù)的高字節(jié)存儲(chǔ)在高地址中,而字?jǐn)?shù)據(jù)的低字節(jié)則存放在低地址中。 union 型數(shù)據(jù)所占的空間等于其最大的成員所占的空間。對(duì)union 型的成員的存取都是相對(duì)于該聯(lián)合體基地址的偏移量為0 處開始,也就是聯(lián)合體的訪問(wèn)不論對(duì)哪個(gè)變量的存取都是從union 的首地址位置開始。如此一解釋,上面的問(wèn)題是否已經(jīng)有了答案呢?
先分析一下,按照上面關(guān)于大小端模式的定義,假設(shè)int 類型變量i 被初始化為1。
以大端模式存儲(chǔ),其內(nèi)存布局如下圖: 以小端模式存儲(chǔ),其內(nèi)存布局如下圖: 變量i 占4 個(gè)字節(jié),但只有一個(gè)字節(jié)的值為1,另外三個(gè)字節(jié)的值都為0。如果取出低地址上的值為0,毫無(wú)疑問(wèn),這是大端模式;如果取出低地址上的值為1,毫無(wú)疑問(wèn),這是小端模式。既然如此,我們完全可以利用union 類型數(shù)據(jù)的特點(diǎn):所有成員的起始地址一致。
到現(xiàn)在,應(yīng)該知道怎么寫了吧?參考答案如下:
int checkSystem( )
{
? ?union check
? ?{
? ? ? int i;
? ? ? char ch;
? ?} c;
? ?c.i = 1;
? ?return (c.ch ==1);
}
現(xiàn)在你可以用這個(gè)函數(shù)來(lái)測(cè)試你當(dāng)前系統(tǒng)的存儲(chǔ)模式了。當(dāng)然你也可以不用函數(shù)而直接去查看內(nèi)存來(lái)確定當(dāng)前系統(tǒng)的存儲(chǔ)模式。如下圖: 圖中0x01 的值存在低地址上,說(shuō)明當(dāng)前系統(tǒng)為小端模式。
不過(guò)要說(shuō)明的一點(diǎn)是,某些系統(tǒng)可能同時(shí)支持這兩種存儲(chǔ)模式,你可以用硬件跳線或在編譯器的選項(xiàng)中設(shè)置其存儲(chǔ)模式。
留個(gè)問(wèn)題:在x86 系統(tǒng)下,輸出的值為多少?
#include <stdio.h>
intmain()
{
? ?int a[5]={1,2,3,4,5};
? ?int *ptr1=(int *)(&a+1);
? ?int *ptr2=(int *)((int)a+1);
? ?printf("%x,%x",ptr1[-1],*ptr2);
? ?return 0;
}
union 維護(hù)足夠的空間來(lái)置放多個(gè)數(shù)據(jù)成員中的“一種”,而不是為每一個(gè)數(shù)據(jù)成員配置空間,在union 中所有的數(shù)據(jù)成員共用一個(gè)空間,同一時(shí)間只能儲(chǔ)存其中一個(gè)數(shù)據(jù)成員,所有的數(shù)據(jù)成員具有相同的起始地址。例子如下:
union StateMachine
{
? ?char character;
? ?int number;
? ?char *str;
? ?double exp;
};
一個(gè)union 只配置一個(gè)足夠大的空間以來(lái)容納最大長(zhǎng)度的數(shù)據(jù)成員,以上例而言,最大長(zhǎng)度是double 型態(tài),所以StateMachine 的空間大小就是double 數(shù)據(jù)類型的大小。
在C++里,union 的成員默認(rèn)屬性頁(yè)為public。union 主要用來(lái)壓縮空間。如果一些數(shù)據(jù)不可能在同一時(shí)間同時(shí)被用到,則可以使用union。
一、大小端模式對(duì)union 類型數(shù)據(jù)的影響
下面再看一個(gè)例子:union
{
? ?int i;
? ?char a[2];
}*p, u;
p =&u;
p->a[0] = 0x39;
p->a[1] = 0x38;
p.i 的值應(yīng)該為多少呢?
這里需要考慮存儲(chǔ)模式:大端模式和小端模式。
二、如何用程序確認(rèn)當(dāng)前系統(tǒng)的存儲(chǔ)模式?
上述問(wèn)題似乎還比較簡(jiǎn)單,那來(lái)個(gè)有技術(shù)含量的:請(qǐng)寫一個(gè)C 函數(shù),若處理器是Big_endian 的,則返回0;若是Little_endian 的,則返回1。先分析一下,按照上面關(guān)于大小端模式的定義,假設(shè)int 類型變量i 被初始化為1。
以大端模式存儲(chǔ),其內(nèi)存布局如下圖: 以小端模式存儲(chǔ),其內(nèi)存布局如下圖: 變量i 占4 個(gè)字節(jié),但只有一個(gè)字節(jié)的值為1,另外三個(gè)字節(jié)的值都為0。如果取出低地址上的值為0,毫無(wú)疑問(wèn),這是大端模式;如果取出低地址上的值為1,毫無(wú)疑問(wèn),這是小端模式。既然如此,我們完全可以利用union 類型數(shù)據(jù)的特點(diǎn):所有成員的起始地址一致。
到現(xiàn)在,應(yīng)該知道怎么寫了吧?參考答案如下:
int checkSystem( )
{
? ?union check
? ?{
? ? ? int i;
? ? ? char ch;
? ?} c;
? ?c.i = 1;
? ?return (c.ch ==1);
}
現(xiàn)在你可以用這個(gè)函數(shù)來(lái)測(cè)試你當(dāng)前系統(tǒng)的存儲(chǔ)模式了。當(dāng)然你也可以不用函數(shù)而直接去查看內(nèi)存來(lái)確定當(dāng)前系統(tǒng)的存儲(chǔ)模式。如下圖: 圖中0x01 的值存在低地址上,說(shuō)明當(dāng)前系統(tǒng)為小端模式。
不過(guò)要說(shuō)明的一點(diǎn)是,某些系統(tǒng)可能同時(shí)支持這兩種存儲(chǔ)模式,你可以用硬件跳線或在編譯器的選項(xiàng)中設(shè)置其存儲(chǔ)模式。
留個(gè)問(wèn)題:在x86 系統(tǒng)下,輸出的值為多少?
#include <stdio.h>
intmain()
{
? ?int a[5]={1,2,3,4,5};
? ?int *ptr1=(int *)(&a+1);
? ?int *ptr2=(int *)((int)a+1);
? ?printf("%x,%x",ptr1[-1],*ptr2);
? ?return 0;
}
總結(jié)
以上是生活随笔為你收集整理的C语言union关键字的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: IOS基础之segue使用,
- 下一篇: 值得借鉴的30条好习惯