电子说
c_name(type_name value)
其中,c_name为类名,type_name是要转换的类型名称。( 注: 在使用的时候要注意隐式转换可能带来的误解和错误,恰当的使用explicit,防止其被用于隐式转换)
operator type_name()
虽然该函数没有声明返回类型,但需要在函数实现的的最后返回所需类型的值。
在类声明中声明的结构、类或枚举,它们的作用域为整个类。这种声明不会创建数据对象,而只是指定了可以在类中使用的类型。如果声明是在私有部分进行的,那么只能在这个类中使用。如果是在公部分声明的,则该结构不仅可以在类中使用,而且还可以通过类名::嵌套结构
的方式在类的外面使用。
对于类Queue,
class Queue
{
public:
const int qsize;
int num;
}
在编写Queue构造函数的时候,由于qsize是常量,所以只能对其进行初始化,但不能对其进行赋值,从概念上来说,在调用构造函数的时候,对象是在构造函数括号中代码执行之前就被创建,因此,对于const数据成员,必须在执行到构造函数体之前,即创建对象的时进行初始化。c++提供了一个特殊的语法来完成上述工作,即成员初始化列表。
成员初始化列表由逗号分隔的初始化列表组成(前面带冒号)。它位于参数列表的右括号之后、函数体左括号之前。对于Queue其构造函数可写为:
Queue::Queue(int qs):qsize(qs)
{
num = 0;
}
//或者
Queue::Queue(int qs):qsize(qs),num(0) //初始化列表也适用于普通的数据成员
{
}
对于被声明为引用的类成员,也只能使用类成员初始化列表的方法进行初始化。
注 :不能将成员初始化列表用于构造函数之外的其他类方法。
c++11允许类内初始化,即在类定义中进行初始化。
例如:
class Queue
{
private:
...
Node * front = NULL;
enum {Q_SIZE = 10};
Node * rear = NULL;
int items = 0;
const int qsize = Q_SIZE;
}
这与使用成员初始化列表等价,然而,使用成员初始化列表的构造函数将覆盖相应的类内初始化。
全部0条评论
快来发表一下你的评论吧 !