c之資料型別

2021-08-15 12:56:30 字數 2669 閱讀 8764

在 c 語言中,資料型別指的是用於宣告不同型別的變數或函式的乙個廣泛的系統。變數的型別決定了變數儲存占用的空間,以及如何解釋儲存的位模式。

c 中的型別可分為以下幾種:

序號型別與描述

1基本型別:

它們是算術型別,包括兩種型別:整數型別和浮點型別。

2列舉型別:

它們也是算術型別,被用來定義在程式中只能賦予其一定的離散整數值的變數。

3void 型別:

型別說明符 void 表明沒有可用的值。

4派生型別:

它們包括:指標型別、陣列型別、結構型別、共用體型別和函式型別。

陣列型別和結構型別統稱為聚合型別。函式的型別指的是函式返回值的型別。在本章節接下來的部分我們將介紹基本型別,其他幾種型別會在後邊幾個章節中進行講解。

下表列出了關於標準整數型別的儲存大小和值範圍的細節:

型別儲存大小

值範圍char

1 位元組

-128 到 127 或 0 到 255

unsigned char

1 位元組

0 到 255

signed char

1 位元組

-128 到 127

int2 或 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

>

intmain()

當您在 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

>

intmain()

當您在 linux 上編譯並執行上面的程式時,它會產生下列結果:

float

儲存最大位元組數:4

float

最小值:

1.175494e-38

float

最大值:

3.402823e+38

精度值:

6

void 型別指定沒有可用的值。它通常用於以下三種情況下:

序號型別與描述

1函式返回為空

c 中有各種函式都不返回值,或者您可以說它們返回空。不返回值的函式的返回型別為空。例如void exit (int status);

2函式引數為空

c 中有各種函式不接受任何引數。不帶引數的函式可以接受乙個 void。例如int rand(void);

3指標指向 void

型別為 void * 的指標代表物件的位址,而不是型別。例如,記憶體分配函式void *malloc( size_t size );返回指向 void 的指標,可以轉換為任何資料型別。

如果現在您還是無法完全理解 void 型別,不用太擔心,在後續的章節中我們將會詳細講解這些概念。

C 之資料型別

c 之資料型別 c 中的資料型別總的來說可以分為兩大類 1.值型別 常見值型別為 int double float char 結構體等 2.引用型別 如使用者定義的類 介面 字串等 以下簡介幾個常用基本型別 int double float char string這些都是關鍵字,是微軟為了方便定義的...

C 學習之 資料型別

內容摘自書籍 c 程式設計.慕課版 型別 1.整型型別 整型型別代表一種沒有小數點的整數數值。2.浮點型別 浮點型別主要用於處理含有小數的數值型別,包含 float double和decimal三種型別。如果不做任何設定,包含小數點的數值都被認為是double型別。3.布林型別 布林型別主要用來表示...

重溫C 之資料型別

測試環境 vs2015 windows10 c 中整數資料型別有三種 int,long short 在32 位系統中,int型別和 long 型別在記憶體中都佔 4個位元組,short 在記憶體中佔兩個位元組。無符號整型 unsigned 表示的範圍 0 2 32 1 即0 4294967295 有...