類中的常量
有時我們希望某些常量只在類中有效。由于#define 定義的宏常量是全局的,不能
達(dá)到目的,于是想當(dāng)然地覺得應(yīng)該用const 修飾數(shù)據(jù)成員來實(shí)現(xiàn)。const 數(shù)據(jù)成員的確
是存在的,但其含義卻不是我們所期望的。const 數(shù)據(jù)成員只在某個對象生存期內(nèi)是常
量,而對于整個類而言卻是可變的,因?yàn)轭惪梢詣?chuàng)建多個對象,不同的對象其const 數(shù)
據(jù)成員的值可以不同。
不能在類聲明中初始化const 數(shù)據(jù)成員。以下用法是錯誤的,因?yàn)轭惖膶ο笪幢粍?chuàng)
建時,編譯器不知道SIZE 的值是什么。
class A
{…
const int SIZE = 100; // 錯誤,企圖在類聲明中初始化const 數(shù)據(jù)成員
int array[SIZE]; // 錯誤,未知的SIZE
};
const 數(shù)據(jù)成員的初始化只能在類構(gòu)造函數(shù)的初始化表中進(jìn)行,例如
class A
{…
A(int size); // 構(gòu)造函數(shù)
const int SIZE ;
};
A::A(int size) : SIZE(size) // 構(gòu)造函數(shù)的初始化表
{
…
}
A a(100); // 對象 a 的SIZE 值為100
A b(200); // 對象 b 的SIZE 值為200
怎樣才能建立在整個類中都恒定的常量呢?別指望const 數(shù)據(jù)成員了,應(yīng)該用類中
的枚舉常量來實(shí)現(xiàn)。例如
class A
{…
enum { SIZE1 = 100, SIZE2 = 200}; // 枚舉常量
int array1[SIZE1];
int array2[SIZE2];
};
枚舉常量不會占用對象的存儲空間,它們在編譯時被全部求值。枚舉常量的缺點(diǎn)是:
它的隱含數(shù)據(jù)類型是整數(shù),其最大值有限,且不能表示浮點(diǎn)數(shù)(如PI=3.14159)。