在實際問題中, 有些變數的取值被限定在乙個有限的範圍內。例如,乙個星期內只有七天,一年只有十二個月, 乙個班每週有六門課程等等。如果把這些量說明為整型, 字元型或其它型別顯然是不妥當的。 為此,c語言提供了一種稱為「列舉」的型別。在「列舉」型別的定義中列舉出所有可能的取值, 被說明為該「列舉」型別的變數取值不能超過定義的範圍。應該說明的是, 列舉型別是一種基本資料型別,而不是一種構造型別, 因為它不能再分解為任何基本型別。
列舉型別的定義和列舉變數的說明
一、列舉的定義列舉型別定義的一般形式為:
enum 列舉名
;在列舉值表中應羅列出所有可用值。這些值也稱為列舉元素。
例如: enum weekday
;該列舉名為weekday,列舉值共有7個,即一周中的七天。 凡被說明為weekday型別變數的取值只能是七天中的某一天。
二、列舉變數的說明 如同結構和聯合一樣,列舉變數也可用不同的方式說明, 即先定義後說明,同時定義說明或直接說明。設有變數a,b,c被說明為上述的weekday,可採用下述任一種方式:
enum weekday
enum weekday a,b,c;或者為: enum weekday
}a,b,c;或者為: enum
}a,b,c;
列舉型別變數的賦值和使用
列舉型別在使用中有以下規定:
1. 列舉值是常量,不是變數。不能在程式中用賦值語句再對它賦值。例如對列舉weekday的元素再作以下賦值: sun=5;mon=2;sun=mon; 都是錯誤的。
2. 列舉元素本身由系統定義了乙個表示序號的數值,從0 開始順序定義為0,1,2…。如在weekday中,sun值為0,mon值為1, …,sat值為6。
main() a,b,c;
a=sun;
b=mon;
c=tue;
printf("%d,%d,%d",a,b,c);
3. 只能把列舉值賦予列舉變數,不能把元素的數值直接賦予列舉變數。如: a=sum;b=mon; 是正確的。而: a=0;b=1; 是錯誤的。如一定要把數值賦予列舉變數,則必須用強制型別轉換,如: a=(enum weekday)2;其意義是將順序號為2的列舉元素賦予列舉變數a,相當於: a=tue; 還應該說明的是列舉元素不是字元常量也不是字串常量, 使用時不要加單、雙引號。
main() month[31],j;
int i;
j=a;
for(i=1;i<=30;i++);
其中位域列表的形式為: 型別說明符 位網域名稱:位域長度
例如:struct bs
int a:8;
int b:2;
int c:6;
位域變數的說明與結構變數說明的方式相同。 可採用先定義後說明,同時定義說明或者直接說明這三種方式。例如:
struct bs
int a:8;
int b:2;
int c:6;
}data;
說明data為bs變數,共佔兩個位元組。其中位域a佔8位,位域b佔2位,位域c佔6位。對於位域的定義尚有以下幾點說明:
struct bs
unsigned a:4
unsigned :0 /*空域*/
unsigned b:4 /*從下一單元開始存放*/
unsigned c:4
在這個位域定義中,a佔第一位元組的4位,後4位填0表示不使用,b從第二位元組開始,占用4位,c占用4位。
2. 由於位域不允許跨兩個位元組,因此位域的長度不能大於乙個位元組的長度,也就是說不能超過8位二進位。
3. 位域可以無位網域名稱,這時它只用來作填充或調整位置。無名的位域是不能使用的。例如:
struct k
int a:1
int :2 /*該2位不能使用*/
int b:3
int c:2
從以上分析可以看出,位域在本質上就是一種結構型別, 不過其成員是按二進位分配的。
二、位域的使用位域的使用和結構成員的使用相同,其一般形式為: 位域變數名·位網域名稱 位域允許用各種格式輸出。
main() bit,*pbit;
bit.a=1;
bit.b=7;
bit.c=15;
printf("%d,%d,%d\n",bit.a,bit.b,bit.c);
pbit=&bit;
pbit->a=0;
pbit->b&=3;
pbit->c|=1;
printf("%d,%d,%d\n",pbit->a,pbit->b,pbit->c);
上例程式中定義了位域結構bs,三個位域為a,b,c。說明了bs型別的變數bit和指向bs型別的指標變數pbit。這表示位域也是可以使用指標的。
程式的9、10、11三行分別給三個位域賦值。( 應注意賦值不能超過該位域的允許範圍)程式第12行以整型量格式輸出三個域的內容。第13行把位域變數bit的位址送給指標變數pbit。第14行用指標方式給位域a重新賦值,賦為0。第15行使用了復合的位運算子"&=", 該行相當於: pbit->b=pbit->b&3位域b中原有值為7,與3作按位與運算的結果為3(111&011=011,十進位制值為3)。同樣,程式第16行中使用了復合位運算"|=", 相當於: pbit->c=pbit->c|1其結果為15。程式第17行用指標方式輸出了這三個域的值。
型別定義符typedef
c語言不僅提供了豐富的資料型別,而且還允許由使用者自己定義型別說明符,也就是說允許由使用者為資料型別取「別名」。 型別定義符typedef即可用來完成此功能。例如,有整型量a,b,其說明如下: int aa,b; 其中int是整型變數的型別說明符。int的完整寫法為integer,
為了增加程式的可讀性,可把整型說明符用typedef定義為: typedef int integer 這以後就可用integer來代替int作整型變數的型別說明了。 例如: integer a,b;它等效於: int a,b; 用typedef定義陣列、指標、結構等型別將帶來很大的方便,不僅使程式書寫簡單而且使意義更為明確,因而增強了可讀性。例如:
typedef char name[20]; 表示name是字元陣列型別,陣列長度為20。
然後可用name 說明變數,如: name a1,a2,s1,s2;完全等效於: char a1[20],a2[20],s1[20],s2[20]
C語言 連續輸入問題(小白必看)
c語言的連續輸入有三種 1.while scanf d d a,b 其中,是按位取反,1的十六進製制補碼表示為0xffffffff,f是二進位制的1111,取反後全部變為0,於是while結束,並且只有返回值為eof 即 1 時,其取反值才為0,while迴圈才能結束。例子 第一種連續輸入 incl...
c語言 樹的基礎知識 必看篇
前言 第 一 樹的定義 1 有且只有乙個稱為根的節點 2 有若干個互不相交的子樹,這些子樹本身也是一顆樹 第 二 專業術語 樹的深度 從根節點到最低層,節點的層數 稱之為樹的深度。根節點是第一層 結點的層次 根節點為第一層,根節點的子節點為第2層,以此類推 葉子節點 沒有子節點的節點 非終端節點 實...
C 類模板(新手必看)
類模板是後期c 加入的一種可以大大提高程式設計效率的方法 關鍵字template 用法 template 模板參數列 模板參數列一般格式為class 識別符號 class 類名 我們要寫乙個比較類,類裡面有兩個私有成員 在類裡有求私有成員中的最大值和最小值的兩個公有成員 用來判斷兩個數的大小 下面我...