2.結構和聯(lián)合的區(qū)別
結構和聯(lián)合有下列區(qū)別:
1.結構和聯(lián)合都是由多個不同的數(shù)據(jù)類型成員組成,但在任何同一時刻,聯(lián)合中只存放了一個被選中的成員,而結構的所有成員都存在。
2.對于聯(lián)合的不同成員賦值,將會對其它成員重寫,原來成員的值就不存在了,而對于結構的不同成員賦值是互不影響的。
下面舉一個例了來加對深聯(lián)合的理解。
例4:
main()
{
union{ /*定義一個聯(lián)合*/
int i;
struct{ /*在聯(lián)合中定義一個結構*/
char first;
char second;
}half;
}number;
number.i=0x4241; /*聯(lián)合成員賦值*/
printf("%c%c\n", number.half.first, mumber.half.second);
number.half.first='a'; /*聯(lián)合中結構成員賦值*/
number.half.second='b';
printf("%x\n", number.i);
getch();
}
輸出結果為:
AB
6261
從上例結果可以看出:當給i賦值后,其低八位也就是first和second的值;當給first和second賦字符后,這兩個字符的ASCII碼也將作為i的低八位和高八位。
枚舉(enum)
枚舉是一個被命名的整型常數(shù)的集合,枚舉在日常生活中很常見。
例如表示星期的SUNDAY,MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY,SATURDAY,就是一個枚舉。
枚舉的說明與結構和聯(lián)合相似, 其形式為:
enum 枚舉名{
標識符[=整型常數(shù)],
標識符[=整型常數(shù)],
...
標識符[=整型常數(shù)],
} 枚舉變量;
如果枚舉沒有初始化,即省掉"=整型常數(shù)"時,則從第一個標識符開始,順次賦給標識符0,1,2, ...。但當枚舉中的某個成員賦值后,其后的成員按依次加1的規(guī)則確定其值。
例如下列枚舉說明后,x1,x2,x3,x4的值分別為0,1,2,3。
enum string{x1, x2, x3, x4}x;
當定義改變成:
enum string
{
x1,
x2=0,
x3=50,
x4,
}x;
則x1=0, x2=0, x3=50, x4=51
注意:
1.枚舉中每個成員(標識符)結束符是",",不是";",最后一個成員可省略","。
2.初始化時可以賦負數(shù),以后的標識符仍依次加1。
3.枚舉變量只能取枚舉說明結構中的某個標識符常量。
例如:
enum string
{
x1=5,
x2,
x3,
x4,
};
enum strig x=x3;
此時,枚舉變量x實際上是7。
類型說明
類型說明的格式為:
typedef 類型 定義名;
類型說明只定義了一個數(shù)據(jù)類型的新名字而不是定義一種新的數(shù)據(jù)類型。這里類型是Turbo C許可的任何一種數(shù)據(jù)類型。定義名表示這個類型的新名字。
例如: 用下面語句定義整型數(shù)的新名字:
typedef int SIGNED_INT;
使用說明后,SIGNED_INT就成為int的同義詞了,此時可以用SIGNED_INT定義整型變量。
例如:SIGNED_INT i, j;(與int i, j等效)。
但long SIGNED_INT i, j;是非法的。
typedef同樣可用來說明結構、聯(lián)合以及枚舉。
說明一個結構的格式為:
typedef struct{
數(shù)據(jù)類型 成員名;
數(shù)據(jù)類型 成員名;
...
} 結構名;
此時可直接用結構名定義結構變量了。例如:
typedef struct{
char name[8];
int class;
char subclass[6];
float math, phys, chem, engl, biol;
} student;
student Liuqi;
則Liuqi被定義為結構數(shù)組和結構指針。
相關推薦:計算機等考二級C語言備考:C語言/C++編譯過程北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |