| 
| 
| 聯(lián)合(union): 一、聯(lián)合說明和聯(lián)合變量定義
 聯(lián)合也是一種新的數(shù)據(jù)類型, 它是一種特殊形式的變量。
 聯(lián)合說明和聯(lián)合變量定義與結(jié)構(gòu)十分相似。其形式為:
 union 聯(lián)合名
 {
 數(shù)據(jù)類型 成員名;
 數(shù)據(jù)類型 成員名;
 ...
 }聯(lián)合變量名;
 聯(lián)合表示幾個變量公用一個內(nèi)存位置,在不同的時間保存不同的數(shù)據(jù)類型和不同長度的變量。
 下例表示說明一個聯(lián)合a_bc:
 union a_bc
 {
 int i;
 char mm;
 };
 再用已說明的聯(lián)合可定義聯(lián)合變量。
 例如用上面說明的聯(lián)合定義一個名為lgc的聯(lián)合變量,可寫成:
 union a_bc lgc;
 在聯(lián)合變量lgc中, 整型量i和字符mm公用同一內(nèi)存位置。
 當(dāng)一個聯(lián)合被說明時, 編譯程序自動地產(chǎn)生一個變量,其長度為聯(lián)合中最大的變量長度。
 聯(lián)合訪問其成員的方法與結(jié)構(gòu)相同。同樣聯(lián)合變量也可以定義成數(shù)組或指針,但定義為指針時,也要用->符號, 此時聯(lián)合訪問成員可表示成:
 聯(lián)合名->成員名
 另外, 聯(lián)合既可以出現(xiàn)在結(jié)構(gòu)內(nèi), 它的成員也可以是結(jié)構(gòu)。
 例如:
 struct
 {
 int age;
 char *addr;
 union
 {
 int i;
 char *ch;
 }x;
 }y[10];
 若要訪問結(jié)構(gòu)變量y[1]中聯(lián)合x的成員i, 可以寫成:
 y[1].x.i;
 若要訪問結(jié)構(gòu)變量y[2]中聯(lián)合x的字符串指針ch的第一個字符可寫成:
 *y[2].x.ch;
 若寫成y[2].x.*ch;是錯誤的。
 
 二、結(jié)構(gòu)和聯(lián)合的區(qū)別
 1. 結(jié)構(gòu)和聯(lián)合都是由多個不同的數(shù)據(jù)類型成員組成,但在任何同一時刻,聯(lián)合中只存放了一個被選中的成員, 而結(jié)構(gòu)的所有成員都存在。
 2. 對于聯(lián)合的不同成員賦值,將會對其它成員重寫,原來成員的值就不存在了,而對于結(jié)構(gòu)的不同成員賦值互不影響的。
 下面舉一個例了來加深對聯(lián)合的理解。
 
 main()
 {
 union
 { /*定義一個聯(lián)合*/
 int i;
 struct
 { /*在聯(lián)合中定義一個結(jié)構(gòu)*/
 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)合中結(jié)構(gòu)成員賦值*/
 number.half.second='b';
 printf(%x\n, number.i);
 getch();
 }
 輸出結(jié)果為:
 AB
 6261
 從上例結(jié)果可以看出: 當(dāng)給i賦值后, 其低八位也就是first和second的值;當(dāng)給first和second賦字符后,這兩個字符的ASCII碼也將作為i 的低八位和高八位。
 簡單的說,就是聯(lián)合里面的所有變量共用一個內(nèi)存區(qū)域,區(qū)域大小是所有變量中最大的那個。改動某一個變量的值,其他的值也會隨之改變。
 
 枚舉(enum)
 枚舉是一個被命名的整型常數(shù)的集合,枚舉在日常生活中很常見。
 
 例如表示星期的SUNDAY,MONDAY,TUESDAY,WEDNESDAY,THURSDAY,FRIDAY,SATURDAY,就是一個枚舉。
 枚舉的說明與結(jié)構(gòu)和聯(lián)合相似, 其形式為:
 enum 枚舉名
 {
 標(biāo)識符[=整型常數(shù)],
 標(biāo)識符[=整型常數(shù)],
 ...
 標(biāo)識符[=整型常數(shù)],
 }枚舉變量;
 如果枚舉沒有初始化,即省掉=整型常數(shù)時,則從第一個標(biāo)識符開始,順次賦給標(biāo)識符0,1,2, ...。但當(dāng)枚舉中的某個成員賦值后, 其后的成員按依次加1的規(guī)則確定其值。
 例如下列枚舉說明后,x1, x2, x3, x4的值分別為0, 1, 2, 3。
 enum string{x1, x2, x3, x4}x;
 當(dāng)定義改變成:
 enum string
 {
 x1,
 x2=0,
 x3=50,
 x4,
 }x;
 則x1=0, x2=0, x3=50, x4=51
 注意:
 1. 枚舉中每個成員(標(biāo)識符)結(jié)束符是,, 不是;, 最后一個成員可省略,。
 2. 初始化時可以賦負數(shù), 以后的標(biāo)識符仍依次加1。
 3. 枚舉變量只能取枚舉說明結(jié)構(gòu)中的某個標(biāo)識符常量。
 例如:
 enum string
 {
 x1=5,
 x2,
 x3,
 x4,
 };
 enum strig x=x3;
 此時, 枚舉變量x實際上是7。
 下面看一個例子:
 
 main()
 {
 enum colors {red=1,green,blue}col;
 int cl;
 printf(1=red,2=green,3=blue. seclect: );
 scanf(%d,&cl);
 col=(enum colors) cl; /*強制轉(zhuǎn)換*/
 switch(col)
 {
 case red:
 printf(red\n);
 break;
 case green:
 printf(green\n);
 break;
 case blue:
 printf(blue\n);
 break;
 defalut:
 break;
 }
 }
 
 
 * **類型說明** *
 
 類型說明的格式為:
 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同樣可用來說明結(jié)構(gòu)、聯(lián)合以及枚舉。
 說明一個結(jié)構(gòu)的格式為:
 typedef struct
 {
 數(shù)據(jù)類型 成員名;
 數(shù)據(jù)類型 成員名;
 ...
 } 結(jié)構(gòu)名;
 此時可直接用結(jié)構(gòu)名定義結(jié)構(gòu)變量了。例如:
 typedef struct
 {
 char name[8];
 int class;
 char subclass[6];
 float math, phys, chem, engl, biol;
 }student;
 student Liuqi;
 則Liuqi被定義為結(jié)構(gòu)數(shù)組和結(jié)構(gòu)指針。
 
 
 |  |  |