C 數據類型
在 C 語言中,數據類型指的是用於聲明不同類型的變數或函數的一個廣泛的系統。變數的類型決定了變數存儲佔用的空間,以及如何解釋存儲的位模式。
C 中的類型可分為以下幾種:
序號 | 類型與描述 |
---|---|
1 | 基本類型: 它們是算術類型,包括兩種類型:整數類型和浮點類型。 |
2 | 枚舉類型: 它們也是算術類型,被用來定義在程式中只能賦予其一定的離散整數值的變數。 |
3 | void 類型: 類型說明符 void 表明沒有可用的值。 |
4 | 派生類型: 它們包括:指針類型、數組類型、結構類型、共用體類型和函數類型。 |
數組類型和結構類型統稱為聚合類型。函數的類型指的是函數返回值的類型。在本章節接下來的部分我們將介紹基本類型,其他幾種類型會在後邊幾個章節中進行講解。
整數類型
下表列出了關於標準整數類型的存儲大小和值範圍的細節:
類型 | 存儲大小 | 值範圍 |
---|---|---|
char | 1 位元組 | -128 到 127 或 0 到 255 |
unsigned char | 1 位元組 | 0 到 255 |
signed char | 1 位元組 | -128 到 127 |
int | 2 或 4 位元組 | -32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647 |
unsigned int | 2 或 4 位元組 | 0 到 65,535 或 0 到 4,294,967,295 |
short | 2 位元組 | -32,768 到 32,767 |
unsigned short | 2 位元組 | 0 到 65,535 |
long | 4 位元組 | -2,147,483,648 到 2,147,483,647 |
unsigned long | 4 位元組 | 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
浮點類型
下表列出了關於標準浮點類型的存儲大小、值範圍和精度的細節:
類型 | 存儲大小 | 值範圍 | 精度 |
---|---|---|---|
float | 4 位元組 | 1.2E-38 到 3.4E+38 | 6 位小數 |
double | 8 位元組 | 2.3E-308 到 1.7E+308 | 15 位小數 |
long double | 16 位元組 | 3.4E-4932 到 1.1E+4932 | 19 位小數 |
頭檔 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 類型,不用太擔心,在後續的章節中我們將會詳細講解這些概念。