C語言 基礎一 資料型別

2021-10-07 20:44:23 字數 3162 閱讀 8778

因為要學習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名字空間裡的...