結構體的宣告
struct tag
variable-list;
例如描述乙個學生:
struct stu
;//分號不能丟
特殊的宣告:
在宣告結構的時候,可以不完全的宣告。
比如:
//匿名結構體型別
struct
x;struct
a[20],*p;
警告:編譯器會把上面的兩個宣告當成完全不同的兩個型別。所以是非法的。
結構的自引用
struct node
;typedef struct node
node;
結構體變數的定義和初始化
有了結構體型別,則如下定義變數。
struct point
p1; //宣告型別的同時定義變數p1;
struct point p2; //定義結構體變數p2
//初始化:定義變數的同時賦初值
struct point p3=;
struct stu //型別宣告
;struct stu s=;//初始化
struct stu //型別宣告
n1=,null}; //結構體巢狀初始化
struct node n2=, null};
結構體只能整體初始化,不能被整體賦值。
結構體內存對齊
結構體內存對齊規則:
1.第乙個成員在與結構體變數偏移量為0的位址處。
2.其他成員變數要對齊到某個數字(對其數)的整數倍的位址處。
對齊數=編譯器預設的乙個對齊數與該成員大小的較小值。vs中預設值為8,linux中的預設值為4.
3.結構體總大小為最大對齊數(每個成員變數都有乙個對齊數)的整數倍。
4.如果巢狀了結構體的情況,巢狀的結構體對齊到自己的最大對齊數的整數倍處,結構體的整體大小就是所有最大對齊數(含巢狀結構體的對齊數)的整數倍。
為什麼要記憶體對齊
1.平台原因(移植原因):不是所有的硬體平台都能訪問任意位址上的任意資料的;某些硬體平台只能在某些位址處取某些特定型別的資料,否則丟擲硬體異常。
2.效能原因:資料結構(尤其是棧)應該盡可能地在自然邊界上對齊。原因在於,為了訪問未對齊的記憶體,處理器需要作兩次記憶體訪問;而對齊的記憶體訪問僅需要一次訪問。
總體來說:結構體的記憶體對齊是拿空間來換取時間的做法。
**
enum day//星期
;enum ***//性別
;enum color//顏色
;
以上定義的enum day, enum *** ,enum color 都是列舉型別。{}中的內容是列舉型別的可能取值,也叫列舉常量。這些可能取值都是有值的,預設從0開始,一次遞增1.在定義時也可以賦初值。
列舉的優點:
1.增加**的可讀性和可維護性。
2.和#define定義的識別符號比較列舉有型別檢查,更加嚴謹。
3.防止命名汙染(封裝)。
4.便於除錯。
5.使用方便,一次可以定義多個常量。
聯合型別的定義
聯合也是一種特殊的自定義型別,這種型別定義的變數也包含一系列的成員,特徵是這些成員公用同一塊空間(所以聯合也叫共用體)。例如:
//聯合型別的宣告
union un
;//聯合變數的定義
union un un;
//計算聯合變數的大小
printf("%d\n",sizeof(un));
聯合的特點
聯合體內所有成員共享位址,並且聯合體變數同聯合體所有成員位址一樣
聯合的成員是共用同一快記憶體空間的。這樣乙個聯合變數的大小,至少是最大成員的大小(因為聯合至少得有能力儲存最大的那個成員)
聯合大小的計算
1.聯合的大小至少是最大成員的大小
2.當最大成員大小不是最大對齊數的整數倍的時候,就要對齊到最大對齊數的整數倍。
自定義型別 結構體 列舉 聯合
結構體 所謂結構體,就是將一大堆值放在一起,建立乙個新的型別,這些成員可以是不同型別的變數。struct tag variable list tag 要求 1.見名知意 2.可以省略 3.不建議省略 member list c語言中,不能為空 variable list 變數列表,可以省略,建議省略...
自定義型別 結構體,列舉,聯合
首先先說一下c語言的資料型別,其框架型別如圖所示 今天主要說一下結構體,列舉,聯合這三種自定義型別。1,結構體 1.1 結構體的宣告 結構體是一些值的集合,這些值稱為成員變數,結構體的每個成員可以是不同型別得變數。1 結構體的成員 結構體的成員可以是標量,陣列,指標,甚至是其他結構體。2 結構體的宣...
自定義型別 結構體,列舉,聯合
結構的成員可能具有不同的型別.而且,每個結構成員都有名字,所以為了選擇特定的結構成員需要指明結構成員的名字而不是他的位置.和陣列一樣,結構變數也可以在宣告的同時進行初始化.為了對結構進行初始化,要把待儲存到結構中的值的列表準備好並用花括號括起來.初始化式中的值必須按照結構成員的順序進行顯示,結構初始...