C 資料型別

2021-08-27 14:14:58 字數 3094 閱讀 6030

有時候突然想不起來某些資料型別佔多少個位元組,乾脆轉過來看吧。

給出幾篇參考:

c語言基本資料型別short、int、long、char、float、double

size_t 這個型別的意義是什麼?

c 資料型別

目錄

c 資料型別

整數型別 例項

浮點型別 例項

void 型別

在 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

#include

int main()

printf("int 儲存大小 : %lu \n", sizeof(int));

return 0;

%lu為 32 位無符號整數,詳細說明檢視 c 庫函式 - printf()。

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

#include

int main() {

printf("float 儲存最大位元組數 : %lu \n", sizeof(float));

printf("float 最小值: %e\n", flt_min );

printf("float 最大值: %e\n", flt_max );

printf("精度值: %d\n", flt_dig );

return 0;

%e為以指數形式輸出單、雙精度實數,詳細說明檢視 c 庫函式 - printf()。

當您在 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 的指標,可以轉換為任何資料型別。

C 資料型別

一般來說,計算機要儲存和處理不同的資料型別,在c 中有基本的資料型別和使用者自定義資料型別以及引用型資料。我們先學習下基本的資料型別,也就是系統自帶的資料型別。每種資料型別都要佔據系統記憶體的一定空間,例如c 中的整數int 乙個整數佔4個位元組,也就是32位 計算機是用0和1二進位制來表示和處理資...

c 資料型別

型別可分為 值型別,引用型別 值型別 直接存放真正的資料,值型別都有固定的長度,值型別的變數都儲存在 堆疊 stack 上。作為值型別的變數,每個都有自己的資料,因此對乙個變數的操作不會影響其他變數。引用型別 儲存讀資料的記憶體位址的引用,位於受管制的堆 heap 上作為引用型別的變數可以引 用同一...

C 資料型別

bool system.boolean 1位元組 byte system.byte 1位元組無符號 sbyte system.sbyte 1位元組有符號 short system.int16 2位元組 ushort system.uint16 2位元組 int system.int32 4位元組 u...