### 3. 數據類型
在 C 語言中,數據類型指的是用于聲明不同類型的變量或函數的一個廣泛的系統。變量的類型決定了變量存儲占用的空間,以及如何解釋存儲的位模式。
C 中的類型可分為以下幾種:
| 類型 | 說明 |
| --- | --- |
| 基本類型 | 它們是算術類型,包括兩種類型:整數類型和浮點類型。 |
|枚舉類型 | 它們也是算術類型,被用來定義在程序中只能賦予其一定的離散整數值得變量。 |
|void 類型 | 類型說明符 void 表名沒有可用的值 |
|派生類型| 它們包括:指針類型、數組類型、結構類型、共用體類型和函數類型。 |
數組類型和結構類型統稱為聚合類型。函數的類型指的是函數返回值的類型。
**整數類型**
下表列出了關于標準整數類型的存儲大小和值范圍的細節
|類型 | 32 位機/單位:字節 | 64 位機/單位:字節 | 值范圍 |
| --- | --- | --- | --- |
| char | 1 | 1 | -128 到 127 或 0 到 255 |
|unsigned char | 1| 1| 0 到 255
|int| 4| 4| -32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647
|unsigned int| 4| 4| 0 到 65,535 或 0 到 4,294,967,295
|short| 2| 2| -32,768 到 32,767 |
|unsigned short |2| 2| 0 到 65,535|
|long | 4 | 8| -2,147,483,648 到 2,147,483,647|
|unsigned long| 4| 8| 0 到 4,294,967,295 |
>[info] 注意: 各種類型的存儲大小與系統位數有關,但目前通用的以 64 為系統為主。
以下列出了32位系統與64位系統的存儲大小的差別(windows 相同):

**浮點類型**
| 類型 | 比特(位)數 | 有效數字 | 取值范圍 |
| --- | --- | --- | --- |
|float | 4 | 6~7 | 1.2E-38 到 3.4E+38 |
|double |8 |15~16 |2.3E-308 到 1.7E+308 |
|long double |16 | 18~19| 3.4E-4932 到 1.1E+4932 |
他們的字節,精度,取值范圍都可以通過代碼打印實現,如下:
```
#include <stdio.h>
//#include <limits.h>
#include <float.h>
#include <stdlib.h>
void main() {
/**
* 整數類型
*/
printf("整數類型 \n");
//char 1 字節
printf("char 存儲大小: %lu \n", sizeof(char));
printf("unsinged char 存儲大小: %lu \n", sizeof(unsigned char));
//short 2 字節
printf("short 存儲大小: %lu \n", sizeof(short));
printf("unsinged short 存儲大小: %lu \n", sizeof(unsigned short));
//int 4 字節
printf("int 存儲大小: %lu \n", sizeof(int));
printf("unsinged int 存儲大小: %lu \n", sizeof(unsigned int));
//long 4/8 字節
printf("long 存儲大小: %lu \n", sizeof(long));
printf("unsinged long 存儲大小: %lu \n", sizeof(unsigned long));
/**
* 浮點類型
*/
printf("\n 浮點類型 \n");
//float 4 字節 ,精度 6 位小數
printf("float 存儲最大字節數:%lu \n", sizeof(float));
printf("float 最小值:%e \n", FLT_MIN);
printf("float 最大值:%e \n", FLT_MAX);
printf("float 精度值:%d \n", FLT_DIG);
//double 8 字節
printf("double 存儲最大字節數:%d \n", sizeof(double));
printf("double 最小值:%e \n", DBL_MIN);
printf("double 最大值:%e \n", DBL_MAX);
printf("double 精度值:%d \n", DBL_DIG);
//long double 16 字節
printf("long double 存儲最大字節數:%lu byte \n", sizeof(long double));
printf("long double 最小值:%lg \n", LDBL_MIN);
printf("long double 最大值:%lg \n", LDBL_MAX);
printf("long double 精度值:%d \n", LDBL_DIG);
}
```
輸出結果
```
整數類型
char 存儲大小: 1
unsinged char 存儲大小: 1
short 存儲大小: 2
unsinged short 存儲大小: 2
int 存儲大小: 4
unsinged int 存儲大小: 4
long 存儲大小: 4
unsinged long 存儲大小: 4
浮點類型
float 存儲最大字節數:4
float 最小值:1.175494e-38
float 最大值:3.402823e+38
float 精度值:6
double 存儲最大字節數:8
double 最小值:2.225074e-308
double 最大值:1.797693e+308
double 精度值:15
long double 存儲最大字節數:8 byte
long double 最小值:2.22507e-308
long double 最大值:1.79769e+308
long double 精度值:15
請按任意鍵繼續. . .
```
可以通過 sizeof 關鍵字來獲取數據類型占用內存的大小。
上面代碼可以看到了打印中出現了很多不識的 scanf() 格式控制符,我總結了一個表,可以參考下:
| 格式控制符 | 說明 |
| --- | --- |
| %c | 讀取一個單一的字符 |
|%hd、%d、%ld | 讀取一個十進制整數,并分別賦值給 short、int、long 類型
|%ho、%o、%lo | 讀取一個八進制整數(可帶前綴也可不帶),并分別賦值給 short、int、long 類型
|%hx、%x、%lx | 讀取一個十六進制整數(可帶前綴也可不帶),并分別賦值給 short、int、long 類型
|%hu、%u、%lu| 讀取一個無符號整數,并分別賦值給 unsigned short、unsigned int、unsigned long 類型
|%f、%lf |讀取一個十進制形式的小數,并分別賦值給 float、double 類型
|%e、%le | 讀取一個指數形式的小數,并分別賦值給 float、double 類型
|%g、%lg| 既可以讀取一個十進制形式的小數,也可以讀取一個指數形式的小數,并分別賦值給 float、double 類型
|%s | 讀取一個字符串(以空白符為結束)
- 前言
- JNI基礎知識
- C語言知識點總結
- ①基本語法
- ②數據類型
- 枚舉類型
- 自定義類型(類型定義)
- ③格式化輸入輸出
- printf函數
- scanf函數
- 編程規范
- ④變量和常量
- 局部變量和外部變量
- ⑤類型轉換
- ⑥運算符
- ⑦結構語句
- 1、分支結構(選擇語句)
- 2、循環結構
- 退出循環
- break語句
- continue語句
- goto語句
- ⑧函數
- 函數的定義和調用
- 參數
- 函數的返回值
- 遞歸函數
- 零起點學通C語言摘要
- 內部函數和外部函數
- 變量存儲類別
- ⑨數組
- 指針
- 結構體
- 聯合體(共用體)
- 預處理器
- 預處理器的工作原理
- 預處理指令
- 宏定義
- 簡單的宏
- 帶參數的宏
- 預定義宏
- 文件包含
- 條件編譯
- 內存中的數據
- C語言讀文件和寫文件
- JNI知識點總結
- 前情回顧
- JNI規范
- jni開發
- jni開發中常見的錯誤
- JNI實戰演練
- C++(CPP)在Android開發中的應用
- 掘金網友總結的音視頻開發知識
- 音視頻學習一、C 語言入門
- 1.程序結構
- 2. 基本語法
- 3. 數據類型
- 4. 變量
- 5. 常量
- 6. 存儲類型關鍵字
- 7. 運算符
- 8. 判斷
- 9. 循環
- 10. 函數
- 11. 作用域規則
- 12. 數組
- 13. 枚舉
- 14. 指針
- 15. 函數指針與回調函數
- 16. 字符串
- 17. 結構體
- 18. 共用體
- 19. typedef
- 20. 輸入 & 輸出
- 21.文件讀寫
- 22. 預處理器
- 23.頭文件
- 24. 強制類型轉換
- 25. 錯誤處理
- 26. 遞歸
- 27. 可變參數
- 28. 內存管理
- 29. 命令行參數
- 總結
- 音視頻學習二 、C++ 語言入門
- 1. 基本語法
- 2. C++ 關鍵字
- 3. 數據類型
- 4. 變量類型
- 5. 變量作用域
- 6. 常量
- 7. 修飾符類型
- 8. 存儲類
- 9. 運算符
- 10. 循環
- 11. 判斷
- 12. 函數
- 13. 數學運算
- 14. 數組
- 15. 字符串
- 16. 指針
- 17. 引用
- 18. 日期 & 時間
- 19. 輸入輸出
- 20. 數據結構
- 21. 類 & 對象
- 22. 繼承
- 23. 重載運算符和重載函數
- 24. 多態
- 25. 數據封裝
- 26. 接口(抽象類)
- 27. 文件和流
- 28. 異常處理
- 29. 動態內存
- 30. 命名空間
- 31. 預處理器
- 32. 多線程
- 總結
- 音視頻學習 (三) JNI 從入門到掌握
- 音視頻學習 (四) 交叉編譯動態庫、靜態庫的入門學習
- 音視頻學習 (五) Shell 腳本入門
- 音視頻學習 (六) 一鍵編譯 32/64 位 FFmpeg 4.2.2
- 音視頻學習 (七) 掌握音頻基礎知識并使用 AudioTrack、OpenSL ES 渲染 PCM 數據
- 音視頻學習 (八) 掌握視頻基礎知識并使用 OpenGL ES 2.0 渲染 YUV 數據
- 音視頻學習 (九) 從 0 ~ 1 開發一款 Android 端播放器(支持多協議網絡拉流/本地文件)
- 音視頻學習 (十) 基于 Nginx 搭建(rtmp、http)直播服務器
- 音視頻學習 (十一) Android 端實現 rtmp 推流
- 音視頻學習 (十二) 基于 FFmpeg + OpenSLES 實現音頻萬能播放器
- 音視頻學習 (十三) Android 中通過 FFmpeg 命令對音視頻編輯處理(已開源)