一、c++ 資料型別
使用程式語言進行程式設計時,需要用到各種變數來儲存各種資訊。變數保留的是它所儲存的值的記憶體位置。這意味著,當您建立乙個變數時,就會在記憶體中保留一些空間。
您可能需要儲存各種資料型別(比如字元型、寬字元型、整型、浮點型、雙浮點型、布林型等)的資訊,作業系統會根據變數的資料型別,來分配記憶體和決定在保留記憶體中儲存什麼。
1.1 基本的內建型別
在c++中 為程式設計師們提供了種類豐富的內建資料型別和使用者自定義的資料型別。下表列出了七種基本的c++資料型別:
型別關鍵字
型別關鍵字
布林型bool
字元型char
整型int
浮點型float
雙浮點型
double
無型別void
寬字元型
wchar_t
wchar_t 是這樣來的:
typedef
short
int wchar_t;
因此 wchar_t 實際上的空間是和 short int 一樣。
一些基本型別可以使用乙個或多個型別修飾符進行修飾:
注意:在不同的作業系統會有所差異。
型別
位範圍char
1 個位元組
-128 到 127 或者 0 到 255
unsigned char
1 個位元組
0 到 255
signed char
1 個位元組
-128 到 127
int4 個位元組
-2147483648 到 2147483647
unsigned int
4 個位元組
0 到 4294967295
signed int
4 個位元組
-2147483648 到 2147483647
short int
2 個位元組
-32768 到 32767
unsigned short int
2 個位元組
0 到 65,535
signed short int
2 個位元組
-32768 到 32767
long int
8 個位元組
-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
signed long int
8 個位元組
-9,223,372,036,854,775,808 到 9,223,372,036,854,775,807
unsigned long int
8 個位元組
0 to 18,446,744,073,709,551,615
float
4 個位元組
+/- 3.4e +/- 38 (~7 個數字)
double
8 個位元組
+/- 1.7e +/- 308 (~15 個數字)
long double
16 個位元組
+/- 1.7e +/- 308 (~15 個數字)
wchar_t
2 或 4 個位元組
1 個寬字元
從上面的**可得知,變數的大小會根據編譯器和所使用的電腦而有所不同。
如下示列會輸出您電腦上各種資料型別的大小。
#include
#include
#include
using namespace std;
intmain()
此示列中使用了 endl,這將在每一行後插入乙個換行符,<< 運算子用於向螢幕傳多個值。我們也使用 sizeof() 函式來獲取各種資料型別的大小。
在上面的**被編譯和執行時,它會產生如下的結果,結果會根據所使用的計算機(作業系統)而有所不同:
type:**
****
****
**size***
****
****
***bool: 占用位元組數:1 最大值:1 最小值:0
char
: 占用位元組數:1 最大值: 最小值:?
signed
char
: 占用位元組數:1 最大值: 最小值:?
unsigned
char
: 占用位元組數:1 最大值:? 最小值:
wchar_t: 占用位元組數:4 最大值:2147483647 最小值:-
2147483648
short
: 占用位元組數:2 最大值:32767 最小值:-
32768
int: 占用位元組數:4 最大值:2147483647 最小值:-
2147483648
unsigned
: 占用位元組數:4 最大值:4294967295 最小值:0
long
: 占用位元組數:8 最大值:9223372036854775807 最小值:-
9223372036854775808
unsigned
long
: 占用位元組數:8 最大值:18446744073709551615 最小值:0
double
: 占用位元組數:8 最大值:1.79769e+308 最小值:2.22507e-308
long
double
: 占用位元組數:16 最大值:1.18973e+4932 最小值:3.3621e-4932
float
: 占用位元組數:4 最大值:3.40282e+38 最小值:1.17549e-38
size_t: 占用位元組數:8 最大值:18446744073709551615 最小值:0
string: 占用位元組數:24
type:**
****
****
**size***
****
****
***
1.2 typedef 宣告
你可以使用 typedef 為乙個已有的型別取乙個新的名字。下面是使用 typedef 定義乙個新型別的語法:
typedef type newname;
例如,下面的語句會告訴編譯器,foo是 int 的另乙個名稱:
typedef
int foo;
現在,下面的宣告是完全合法的,它建立了乙個整型變數 distance:
foo distance;
1.3 列舉型別
在c++中列舉型別(enumeration)是一種派生資料型別,它是由使用者定義的若干列舉常量的集合。
假如乙個變數只有幾種可能的值,可以定義為列舉(enumeration)型別。所謂"列舉"是指將變數的值一一枚舉出來,變數的值只能在列舉出來的值的範圍內。
建立列舉,需要使用關鍵字 enum。列舉型別的一般形式為:
enum 列舉名 列舉變數;
假如列舉沒有初始化, 即省掉"=整型常數"時, 則從第乙個識別符號開始。
例如,下面的**定義了乙個顏色列舉,變數 c 的型別為 color。最後,c 被賦值為 「blue」。
enum color c;
c = blue;
在預設情況下,第乙個名稱的值為 0,第二個名稱的值為 1,第三個名稱的值為 2,以此類推。但是,您可以給名稱賦予乙個特殊的值,只需要新增乙個初始值即可。例如,在下面的列舉中,green 的值為 5。
enum color
;
在這裡,blue 的值為 6,因為在預設情況下,每個名稱都會比它前面乙個名稱大 1,但 red 的值依然為 0。 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...