C++ 變量類型
變量其實只不過是程序可操作的存儲區的名稱。C++ 中每個變量都有指定的類型,類型決定了變量存儲的大小和布局,該範圍內的值都可以存儲在內存中,運算符可應用於變量上。
變量的名稱可以由字母、數字和下劃線字符組成。它必須以字母或下劃線開頭。大寫字母和小寫字母是不同的,因為 C++ 是大小寫敏感的。
基於前一章講解的基本類型,有以下幾種基本的變量類型,將在下一章中進行講解:
類型 | 描述 |
---|---|
bool | 存儲值 true 或 false。 |
char | 通常是一個八位字節(一個字符)。這是一個整數類型。 |
int | 對機器而言,整數的最自然的大小。 |
float | 單精度浮點值。單精度是這樣的格式,1位符號,8位指數,23位小數。
|
double | 雙精度浮點值。雙精度是1位符號,11位指數,52位小數。 |
void | 表示類型的缺失。 |
wchar_t | 寬字符類型。 |
C++ 也允許定義各種其他類型的變量,比如枚舉、指針、數組、引用、數據結構、類等等,這將會在後續的章節中進行講解。
下面我們將講解如何定義、聲明和使用各種類型的變量。
C++ 中的變量定義
變量定義就是告訴編譯器在何處創建變量的存儲,以及如何創建變量的存儲。變量定義指定一個數據類型,併包含了該類型的一個或多個變量的列表,如下所示:
type variable_list;
在這里,type 必須是一個有傚的 C++ 數據類型,可以是 char、wchar_t、int、float、double、bool 或任何用戶自定義的對象,variable_list 可以由一個或多個標識符名稱組成,多個標識符之間用逗號分隔。下面列出幾個有傚的聲明:
行 int i, j, k; 聲明併定義了變量 i、j 和 k,這指示編譯器創建類型為 int 的名為 i、j、k 的變量。
變量可以在聲明的時候被初始化(指定一個初始值)。初始化器由一個等號,後跟一個常量表達式組成,如下所示:
下面列舉幾個實例:
不帶初始化的定義:帶有靜態存儲持續時間的變量會被隱式初始化為 NULL(所有字節的值都是 0),其他所有變量的初始值是未定義的。
C++ 中的變量聲明
變量聲明向編譯器保證變量以給定的類型和名稱存在,這樣編譯器在不需要知道變量完整細節的情況下也能繼續進一步的編譯。變量聲明只在編譯時有它的意義,在程序連接時編譯器需要實際的變量聲明。
當您使用多個文件且只在其中一個文件中定義變量時(定義變量的文件在程序連接時是可用的),變量聲明就顯得非常有用。您可以使用 extern 關鍵字在任何地方聲明一個變量。雖然您可以在 C++ 程序中多次聲明一個變量,但變量只能在某個文件、函數或代碼塊中被定義一次。
實例
嘗試下面的實例,其中,變量在頭部就已經被聲明,但它們是在主函數內被定義和初始化的:
實例
當上面的代碼被編譯和執行時,它會產生下列結果:
30 23.3333
同樣的,在函數聲明時,提供一個函數名,而函數的實際定義則可以在任何地方進行。例如:
C++ 中的左值(Lvalues)和右值(Rvalues)
C++ 中有兩種類型的表達式:
- 左值(lvalue):指向內存位置的表達式被稱為左值(lvalue)表達式。左值可以出現在賦值號的左邊或右邊。
- 右值(rvalue):術語右值(rvalue)指的是存儲在內存中某些地址的數值。右值是不能對其進行賦值的表達式,也就是說,右值可以出現在賦值號的右邊,但不能出現在賦值號的左邊。
變量是左值,因此可以出現在賦值號的左邊。數值型的字面值是右值,因此不能被賦值,不能出現在賦值號的左邊。下面是一個有傚的語句:
int g = 20;
但是下面這個就不是一個有傚的語句,會生成編譯時錯誤:
10 = 20;