在 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位系統為主。為了得到某個型別或某個變數在特定平台上的準確大小,您可以使用sizeof運算子。表示式 sizeof(type) 得到物件或型別的儲存位元組大小。下面的例項演示了獲取 int 型別的大小:以下列出了32位系統與64位系統的儲存大小的差別(windows 相同):
#include #include int main()
%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()
%e為以指數形式輸出單、雙精度實數,詳細說明檢視 c 庫函式 - printf()。
當您在 linux 上編譯並執行上面的程式時,它會產生下列結果:
float 儲存最大位元組數 : 4void 型別指定沒有可用的值。它通常用於以下三種情況下:float 最小值: 1.175494e-38
float 最大值: 3.402823e+38
精度值: 6
序號型別與描述
1函式返回為空
c 中有各種函式都不返回值,或者您可以說它們返回空。不返回值的函式的返回型別為空。例如void exit (int status);
2函式引數為空
c 中有各種函式不接受任何引數。不帶引數的函式可以接受乙個 void。例如int rand(void);
3指標指向 void
型別為 void * 的指標代表物件的位址,而不是型別。例如,記憶體分配函式void *malloc( size_t size );返回指向 void 的指標,可以轉換為任何資料型別。
變數宣告向編譯器保證變數以指定的型別和名稱存在,這樣編譯器在不需要知道變數完整細節的情況下也能繼續進一步的編譯。變數宣告只在編譯時有它的意義,在程式連線時編譯器需要實際的變數宣告。
變數的宣告有兩種情況:
extern int i; //宣告,不是定義如果需要在乙個原始檔中引用另外乙個原始檔中定義的變數,我們只需在引用的檔案中將變數加上 extern 關鍵字的宣告即可。int i; //宣告,也是定義
addtwonum.c 檔案**:
#include /*外部變數宣告*/
extern int x ;
extern int y ;
int addtwonum()
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...