嵌套结构和类
在类声明中声明的结构、枚举、或其他类称为嵌套在类中,其作用域为整个类。这种声明不会创建数据对象,而只是指定了可以在类中使用的类型
- 在私有权限中声明时,只能在类内使用
- 在公有权限中声明时,可以在类外通过作用域解析运算符使用被声明的类型
class Queue
{
private:
//class scope definitions
enum { Q_SIZE = 10 };
struct Node
{
Item item;
struct Node* next;
};
//private class members
Node * front; //头指针
Node* rear; //尾指针
int items; //当前项目数量
const int qsize;//队列的最大长度
public:
...
}
构造函数的成员初始化列表使用方法
从概念上说,调用构造函数时,对象将在花括号中代码被执行之前创建,即给类对象的成员变量分配内存,相当于已经对数据成员进行了初始化。之后再进入花括号,使用常规的赋值方式将值存储到内存中。
但是:
非静态const数据成员(常量)只能进行初始化,不能进行赋值
被声明为引用的类成员,也只能在被创建时初始化。
对于本身就是类对象的成员来说,使用成员初始化列表的方式效率更高。
构造函数成员初始化列表的语法:冒号开始,逗号分隔
class::classy(int n, int m) : mem1(n) , mem2(0),mem3(n*m + 2)
{
//...
};
使用成员初始化列表时的初始化工作是在对象创建时完成的,此时还未执行花括号中的任何代码。
注意事项:
- 这种格式只能用于构造函数
- 非静态const数据成员初始化,必须用这种格式
- 引用数据成员初始化,必须用这种格式
- 数据成员被初始化的顺序与在类声明中的顺序相同,与初始化列表中初始化器的排列顺序无关
C++11的类内初始化
C++11允许直接在类声明初始化,这与在构造函数中使用成员初始化列表等价
//类内初始化
class Classy
{
int mem1 = 10;
const int mem2 = 20
...
};
//使用成员初始化列表
class::Classy() : mem1(10) , mem2(20)
{
...
};
在类内初始化后,如果遇到使用初始化列表的构造函数,在这种情况下,初始化列表将覆盖这些默认初始值。
class Classy
{
int mem1 = 10;
const int mem2 = 20
...
};
class::Classy() : mem1(5) {...}
//mem1 = 5覆盖了类内初始化的默认值10
//mem2仍为20