浅谈C语言的基本数据类型
提示:文章寫完后,目錄可以自動生成,如何生成可參考右邊的幫助文檔
文章目錄
- 前言
- C語言中的基本數據類型
- 1.單位
- 2.基本數據類型
- 3.為什么出現這么多的類型?
- 4.printf()傳參
- 總結
前言
學習內容梳理。
C語言中的基本數據類型
1.單位
談基本數據類型之前,首先需要了解一下計算機的存儲單位。
首先,計算機由邏輯電路組成,邏輯電路通常只有兩個狀態,開關的接通與斷開,這兩種狀態正好可以用“1”和“0”表示。因此,計算機內部采用二進制存儲信息。一個 二進制位包含的信息量稱為比特(Bit)、比特就是組成信息的最小單位。
接下來由小到大談一談其他的存儲單位。
用通俗易懂的方式解釋1字節(Byte)的表示范圍,觀察下方八位二進制數字(由低位往高位看,1個比特位代表1位2進制數),上方是00000000,下方是00000001,表示兩種狀態。由于每一位的狀態都只有0或者1,根據排列組合-> 1位二進制數共有兩種狀態、2位二進制數有4種狀態、3位共8種狀態、以此類題,8位二進制數就有2^8種狀態,由于從0開始,那么其能表示的無符號數就是0~255啦。
00000000 000000012.基本數據類型
接下里說說數據類型,C語言中的基本數據類型有以下幾類:
基本數據類型 大小 表示范圍 char //字符數據類型 1Byte 0~2^8-1個無符號數 short //短整型 2Byte 0~2^16-1個無符號數 int //整形 4Byte 0~2^32-1個無符號數 C中整數默認為int型 long //長整型 4Byte 0~2^32-1個無符號數 (不同的系統和編譯器的大小可能會是8Byte) long long //更長的整形 8Byte 0~2^64-1個無符號數 float //單精度浮點型 4Byte 0~2^32-1個無符號數 double //雙精度浮點型 8Byte 0~2^32-1個無符號數 C中浮點數默認為double型對于整形變量(默認有符號),可以用unsigned(無符號數),signed(有符號數)來修飾。例如:
unsigned char a = 128;我們還可以通過打印sizeof(類型名)來得到數據類型的大小。例如:
#include<stdio.h>int main() {printf("char的大小是%d個字節\n", sizeof(char));printf("int的大小是%d個字節\n", sizeof(int));printf("long的大小是%d個字節\n", sizeof(long));printf("long long的大小是%d個字節\n", sizeof(long long));printf("float的大小是%d個字節\n", sizeof(float));printf("double的大小是%d個字節\n", sizeof(double));return 0; }以上代碼在32位VS2017中運行結果如圖:
學過其他編程語言的朋友可能會發現,以上數據類型并沒有提到字符串型(string),那么C語言中可以表示字符串嗎?答案是可以的, C語言中通過 ->char 字符串名[]= "字符串內容"來定義一個字符串。
3.為什么出現這么多的類型?
4.printf()傳參
printf在傳入參數的時候如果是整形會默認傳入四字節,由于printf是可變參數的函數,所以后面參數的類型是未知的,所以甭管你傳入的是什么類型,printf只會根據類型的不同將用兩種不同的長度存儲。其中8字節的只有long long、float和double(注意float會處理成double再傳入),其他類型都是4字節。所以雖然a + b的類型是char,實際接收時還是用一個四字節整數接收的。另外,讀取時,%lld、%llx等整型方式和%f、%lf等浮點型方式讀8字節,其他讀4字節。
總結
以上就是我關于C語言基本數據類型總結的一些筆記,不足之處、歡迎補充指正!
總結
以上是生活随笔為你收集整理的浅谈C语言的基本数据类型的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据结构 稀疏矩阵的实现方法
- 下一篇: 关于C语言中的结构体内存对齐与位段问题