# C數據類型
在 C 語言中,數據類型指的是用于聲明不同類型的變量或函數的一個廣泛的系統。變量的類型決定了變量存儲占用的空間,以及如何解釋存儲的位模式。
C 中的類型可分為以下幾種:
| 序號 | 類型與描述 |
| --- | --- |
| 1 | 基本類型:它們是算術類型,包括兩種類型:整數類型和浮點類型 |
| 2 | 枚舉類型:它們也是算術類型,被用來定義在程序中只能賦予其一定的離散整數值的變量。 |
| 3 | void 類型:類型說明符 void 表明沒有可用的值。 |
| 4 | 派生類型:它們包括:指針類型、數組類型、結構類型、共用體類型和函數類型。 |
>[danger]數組類型和結構類型統稱為聚合類型。函數的類型指的是函數返回值的類型。在本章節接下來的部分我們將介紹基本類型,其他幾種類型會在后邊幾個章節中進行講解。
## 整數類型
下表列出了關于標準整數類型的存儲大小和值范圍的細節:
| 類型 | 存儲大小 | 值范圍 |
| --- | --- |--- |
| 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()](https://www.runoob.com/cprogramming/c-function-printf.html)。
當您在 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**為以指數形式輸出單、雙精度實數。
當您在 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 的指針,可以轉換為任何數據類型。 |
>[danger]注意:如果現在您還是無法完全理解 void 類型,不用太擔心,在后續的章節中我們將會詳細講解這些概念。
- 空白目錄
- 第一章 c語言簡介
- 1 通俗地理解什么是編程語言
- 2 C語言究竟是一門怎樣的語言
- 第二章 算法簡介&基本語法
- 1 算法簡介
- 2 C 程序結構
- 3 C 基本語法
- 第三章 數據類型
- 1 數據類型
- 2 變量
- 3 常量
- 第四章 運算符
- 1 算術運算符
- 2 關系運算符
- 3 邏輯運算符
- 4 位運算符
- 5 賦值運算符
- 6 雜項運算符(其他運算符)
- 7 c語言中的運算符優先級
- 第五章 控制流
- 1 判斷語句
- 2 switch語句
- 3 循環語句
- 4 流程控制相關案例
- 第六章 指針
- 1 c語言指針概述
- 2 指針的算術運算
- 3 指針數組
- 4 指向指針的指針
- 5 傳遞指針給函數
- 6 從函數返回指針
- 第七章 函數
- 1 函數的語法
- 2 作用域規則
- 3 形參與實參
- 第八章 數組
- 1 C語言中的數組
- 2 多維數組
- 3 傳遞數組給函數
- 4 從函數返回數組
- 第九章 指針
- 1 分鐘徹底理解C語言指針的概念
- 2 C語言指針變量的定義和使用
- 3 C語言指針變量的運算(加法、減法和比較運算)
- 4 C語言數組指針(指向數組的指針)
- 5 C語言字符串指針(指向字符串的指針)
- 第十章 結構體
- 第十一章 練習
- 第十二章 文件操作
- 第十三章 文件操作2