C 資料型別

C 資料型別

在 C 語言中,資料型別指的是用於宣告不同型別的變數或函式的一個廣泛的系統。變數的型別決定了變數儲存佔用的空間,以及如何解釋儲存的位模式。

C 中的型別可分為以下幾種:

序號型別與描述
1基本型別:
它們是算術型別,包括兩種型別:整數型別和浮點型別。
2列舉型別:
它們也是算術型別,被用來定義在程式中只能賦予其一定的離散整數值的變數。
3void 型別:
型別說明符 void 表明沒有可用的值。
4派生型別:
它們包括:指標型別、陣列型別、結構型別、共用體型別和函式型別。

陣列型別和結構型別統稱為聚合型別。函式的型別指的是函式返回值的型別。在本章節接下來的部分我們將介紹基本型別,其他幾種型別會在後邊幾個章節中進行講解。

整數型別

下表列出了關於標準整數型別的儲存大小和值範圍的細節:

型別儲存大小值範圍
char1 位元組-128 到 127 或 0 到 255
unsigned char1 位元組0 到 255
signed char1 位元組-128 到 127
int2 或 4 位元組-32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647
unsigned int2 或 4 位元組0 到 65,535 或 0 到 4,294,967,295
short2 位元組-32,768 到 32,767
unsigned short2 位元組0 到 65,535
long4 位元組-2,147,483,648 到 2,147,483,647
unsigned long4 位元組0 到 4,294,967,295

注意,各種型別的儲存大小與系統位數有關,但目前通用的以64位系統為主。

以下列出了32位系統與64位系統的儲存大小的差別(windows 相同):

為了得到某個型別或某個變數在特定平臺上的準確大小,您可以使用 sizeof 運算子。表示式 sizeof(type) 得到物件或型別的儲存位元組大小。下面的例項演示了獲取 int 型別的大小:

例項

#include <stdio.h> #include <limits.h> int main() { printf("int 儲存大小 : %lu \n", sizeof(int)); return 0; }

%lu 為 32 位無符號整數,詳細說明檢視 C 庫函式 - printf()。

當您在 Linux 上編譯並執行上面的程式時,它會產生下列結果:

int 儲存大小 : 4 

浮點型別

下表列出了關於標準浮點型別的儲存大小、值範圍和精度的細節:

型別儲存大小值範圍精度
float4 位元組1.2E-38 到 3.4E+386 位小數
double8 位元組2.3E-308 到 1.7E+30815 位小數
long double16 位元組3.4E-4932 到 1.1E+493219 位小數

標頭檔案 float.h 定義了巨集,在程式中可以使用這些值和其他有關實數二進位制表示的細節。下面的例項將輸出浮點型別佔用的儲存空間以及它的範圍值:

例項

#include <stdio.h> #include <float.h> int main() { printf("float 儲存最大位元組數 : %lu \n", sizeof(float)); printf("float 最小值: %E\n", FLT_MIN ); printf("float 最大值: %E\n", FLT_MAX ); printf("精度值: %d\n", FLT_DIG ); return 0; }

%E 為以指數形式輸出單、雙精度實數,詳細說明檢視 C 庫函式 - printf()。

當您在 Linux 上編譯並執行上面的程式時,它會產生下列結果:

float 儲存最大位元組數 : 4 
float 最小值: 1.175494E-38
float 最大值: 3.402823E+38
精度值: 6

void 型別

void 型別指定沒有可用的值。它通常用於以下三種情況下:

序號型別與描述
1函式返回為空
C 中有各種函式都不返回值,或者您可以說它們返回空。不返回值的函式的返回型別為空。例如 void exit (int status);
2函式引數為空
C 中有各種函式不接受任何引數。不帶引數的函式可以接受一個 void。例如 int rand(void);
3指標指向 void
型別為 void * 的指標代表物件的地址,而不是型別。例如,記憶體分配函式 void *malloc( size_t size ); 返回指向 void 的指標,可以轉換為任何資料型別。

如果現在您還是無法完全理解 void 型別,不用太擔心,在後續的章節中我們將會詳細講解這些概念。