因為要學習stm32嵌入式開發,c語言就需要重新撿起來啦~快速的過一遍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
int4 位元組
-32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647
unsigned int
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
為了得到某個型別或某個變數在特定平台上的準確大小,可以使用 sizeof 運算子。表示式 sizeof(type) 得到物件或型別的儲存位元組大小。下面的例項演示了獲取 int 型別的大小:
例項
#include
#include
intmain()
(%lu 為 32 位無符號整數)
二、浮點型別
下表列出了關於標準浮點型別的儲存大小、值範圍和精度的細節:
型別儲存大小
值範圍精度
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
#include
intmain()
(%e 為以指數形式輸出單、雙精度實數)
輸出
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 的指標,可以轉換為任何資料型別。
四、基本型別書寫
1、整數
1)預設為10進製 ,10 ,20。
2)以0開頭為8進製,045,021。
3)以0b開頭為2進製,0b11101101。
4)以0x開頭為16進製制,0x21458adf。
整數常量也可以帶乙個字尾,字尾是 u 和 l 的組合,u 表示無符號整數(unsigned),l 表示長整數(long)。字尾可以是大寫,也可以是小寫,u 和 l 的順序任意。
2、小數
單精度常量:2.3f 。
雙精度常量:2.3,預設為雙精度。
當使用小數形式表示時,必須包含整數部分、小數部分,或同時包含兩者。當使用指數形式表示時, 必須包含小數點、指數,或同時包含兩者。帶符號的指數是用 e 或 e 引入的。如314159e-5l
3、字元型常量
用英文單引號括起來,只儲存乙個字元』a』、『b』 、』*』 ,還有轉義字元 『\n』 、』\t』。
4、字串常量
用英文的雙引號引起來 可以儲存多個字元:「abc」。
五、資料型別轉換
c 語言中如果乙個表示式中含有不同型別的常量和變數,在計算時,會將它們自動轉換為同一種型別;在 c 語言中也可以對資料型別進行強制轉換
1、自動轉換規則:
1)浮點數賦給整型,該浮點數小數被捨去;
2)整數賦給浮點型,數值不變,但是被儲存到相應的浮點型變數中;
2、強制型別轉換形式: (型別說明符)(表示式)
例項
#include
intmain()
先計算 x+y 值為 8.8,然後賦值給 a,因為a為整型,所以自取整數部分8,a=8;
接下來 b 把 x+y 強制轉換為整型;
最後 10/i 是兩個整數相除,結果仍為整數 2,把 2 賦給浮點數 f;
x 為浮點型直接輸出。
結果
a=8,b=8,f=2,x=3.6
C語言基礎(一)資料型別(下)
浮點數也稱小數或實數,c語言中用float和double關鍵字來定義小數。其中float為單精度浮點型,double為雙精度浮點型。c語言規定,float型別必須至少能夠表示6位有效數字,且取值範圍至少是10 37 10 37.float型別資料表示的是乙個近似的小數,不是精確地,小數點後n位有誤差...
c 基礎(一) 資料型別
c 的資料型別分為兩類 值和引用,值型是乙個長度固定的資料,引用型是乙個長度可變的。具體來說 值 整數型 浮點數 布林型 字元型 結構 列舉 六種 引用 c 預定義引用 陣列 類 介面 下面具體介紹 整數型 8 16 32 64位,每種又有正負和非負兩種整數,共8種,sbyte byte short...
C 基礎(一) 資料型別
using system namespace base 01 endregion 說明 1 每個程式只能有乙個main方法 2 region 摺疊塊,endregion可以實現 塊摺疊 3 c 需要引用命名空間,類似於c 新增標頭檔案,命名空間裡有相關類。例如console是system名字空間裡的...