C++类中的枚举类型

注:本文来自于WebTrip博文,感谢做者整理。 html

 

《高质量程序设计指南》5.4节 类中的常量
  有时咱们但愿某些常量只在类中有效。
  因为#define 定义的宏常量是全局的,不能达到目的,因而想固然地以为应该用 const 修饰数据成员来实现。const 数据成员的确是存在的,但其含义却不是咱们所指望的。const 数据成员只在某个对象生存期内是常量而对于整个类而言倒是可变的,由于类能够建立多个对象,不一样的对象其 const 数据成员的值能够不一样。 
  不能在类声明中初始化 const 数据成员。如下用法是错误的,由于类的对象未被建立时,编译器不知道 SIZE 的值是什么。 
函数

class  A 
{
  
const int SIZE = 100;   // 错误,企图在类声明中初始化 const 数据成员 
  int array[SIZE];  // 错误,未知的 SIZE 
}

const 数据成员的初始化只能在类构造函数的初始化表中进行,例如
**变量能够在构造函数的函数体中初始化
spa

复制代码
复制代码
class  A 
{
  A(
int  size);   //  构造函数 
   const   int  SIZE ;    
}; 
A::A(
int  size) : SIZE(size)   //  构造函数的



A  a(
100 );  //  对象 a 的 SIZE 值为 100 
A  b( 200 );  //  对象 b 的 SIZE 值为 200 
复制代码
复制代码

  怎样才能创建在整个类中都恒定的常量呢?别期望 const 数据成员了,应该用类中的枚举常量来实现。例如 

设计

class  A 
{
  
enum  { SIZE1  =   100 , SIZE2  =   200 };  //  枚举常量
   int  array1[SIZE1];  
  
int  array2[SIZE2]; 
}; 

  枚举常量不会占用对象的存储空间,它们在编译时被所有求值。枚举常量的缺点是:它的隐含数据类型是整数,其最大值有限,且不能表示浮点数(如 PI=3.14159) 。 htm

相关文章
相关标签/搜索