C之 enum、sizeof、typedef(十一)
首先 enum 是 C 語言中的一種自定義類型,它是一種枚舉類型。enum 值是可以根據需要自定義的整型值,第一個定義的 enum 值默認為 0。默認情況下的 enum 值是在前一個定義值的基礎上加 1,enum 類型的變量只能取定義時的離散值。enum 中定義的值是 C 語言中真正意義上的常量,在一般工程中 enum 多用於定義×××常量。
下來我們就來寫個示例代碼分析下,代碼如下:
#include <stdio.h> enum { ARRAY_SIZE = 5 }; void InitArray(int array[]) { int i = 0; for(i=0; i<ARRAY_SIZE; i++) { array[i] = i + 1; } } void PrintArray(int array[]) { int i = 0; for(i=0; i<ARRAY_SIZE; i++) { printf("%d\n", array[i]); } } int main() { int array[ARRAY_SIZE] = {0}; InitArray(array); PrintArray(array); return 0; }
我們來分析下這個代碼,它利用 enum 定義了常量 ARRAY_SIZE,然後創建數組並打印。我們來看下編譯結果是否如我們所願呢?打印如下:
那麽我們看到打印確實如我們所想。
接下來我們來講講 sizeof 關鍵字,它是編譯器的內置指示符,用於計算類型或變量所占內存打小。那麽它所計算的值在編譯期就已經確定,也就是說在運行期是沒用的。sizeof 於類型時:sizeof(type);用於變量時:sizeof(var) 或 sizeof var。sizeof 是 C語言的內置關鍵字而不是函數,在編譯過程中所有的 sizeof 將被具體的數值所替換,程序的執行過程與 sizeof
#include <stdio.h> int f() { printf("hello world\n"); return 0; } int main() { int var = 0; int size = sizeof(var++); printf("var = %d, size = %d\n", var, size); size = sizeof(f()); printf("size = %d\n", size); return 0; }
我們先來分析下這個代碼,在程序的第14行我們做了 var++,理論上第16行打印出來的結果會是 1 和 4。在程序的第18行看似調用了 f() 函數,那麽照我們的分析,將會在第20行打印出 4,但是在前面硬打印出 hello world 這句話。下來我們來看看是否如我們所分析的那樣呢?
那麽這是怎麽回事呢?跟我們分析的不一樣,var 不等於 1,並且也沒有打印出 hello world 那句。我們來仔細想想上面講的 sizeof 的相關知識,它是在程序的編譯期有效的,也就是說程序運行之後並沒有去執行 var++,所以 var 仍然等於 0。sizeof 是關鍵字而不是函數,所以在程序的第18行並不是去調用 f() 函數,自然也就不會去執行函數裏的打印語句。因為函數的返回值是 int 型,所以打印的值為 4。
最後我們再來講講 typedef 關鍵字。我們通常以為 typedef 是定義一種新的類型,其實不是的。typedef 用於給一個已經存在的數據類型重命名,其本質上是不能產生新的類型的。註意:它命名的類型可以在 typedef 語句之後,但是不能被 unsigned 和 signed 所修飾。
我們以示例代碼來分析下,代碼如下:
#include <stdio.h> typedef int Int32; struct _tag_point { int x; int y; }; typedef struct _tag_point Point; typedef struct { int length; int array[]; } SoftArray; typedef struct _tag_list_node ListNode; struct _tag_list_node { ListNode* next; }; int main() { Int32 i = -100; unsigned Int32 ii = 0; Point p; SoftArray* sa = NULL; ListNode* node = NULL; return 0; }
我們來分析這個代碼,我們在第19行顯然是先重命名後定義的,這種在 C 語言中是合法的。第28行用 unsigned 修飾重命名的類型,這顯然是錯誤的,因此會在28行報錯。第29行相當於 struct _tag_point p;第31行相當於 struct _tag_list_node* node;我們來看看編譯結果
那麽我們註釋掉第28行之後,編譯就通過了。那麽我們今天講解了 enum、sizeof、typedef ,總結如下:1、enum 用於定義離散值類型,並且它定義的值是真正意義上的常量;2、sizeof 是編譯器的內置指示符,不參與程序的執行過程;3、typedef 用於給類型重命名,並且重命名的類型可以在 typedef 語句之後定義。後面我們會繼續對 C 語言的學習。
歡迎大家一起來學習 C 語言,可以加我QQ:243343083。
C之 enum、sizeof、typedef(十一)