类和动态内存分配(二)

电子说

1.2w人已加入

描述

1. 转换函数

  • 若要将单个值转换为类类型,则需要创建对应的类构造函数,其原型大致如下:

c_name(type_name value)

其中,c_name为类名,type_name是要转换的类型名称。( 注: 在使用的时候要注意隐式转换可能带来的误解和错误,恰当的使用explicit,防止其被用于隐式转换)

  • 若要将类转换为其他类型,则需要创建类转换成员函数,其原型大致如下:

operator type_name()

虽然该函数没有声明返回类型,但需要在函数实现的的最后返回所需类型的值。

2. 嵌套结构和类

在类声明中声明的结构、类或枚举,它们的作用域为整个类。这种声明不会创建数据对象,而只是指定了可以在类中使用的类型。如果声明是在私有部分进行的,那么只能在这个类中使用。如果是在公部分声明的,则该结构不仅可以在类中使用,而且还可以通过类名::嵌套结构的方式在类的外面使用。

3. 成员初始化列表

对于类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)  //初始化列表也适用于普通的数据成员
{
}

对于被声明为引用的类成员,也只能使用类成员初始化列表的方法进行初始化。

:不能将成员初始化列表用于构造函数之外的其他类方法。

4. 类内初始化

c++11允许类内初始化,即在类定义中进行初始化。

例如:

class Queue
{
  private:
  ...
    Node * front = NULL;
    enum {Q_SIZE = 10};
    Node * rear = NULL;
    int items = 0;
    const int qsize = Q_SIZE;
}

这与使用成员初始化列表等价,然而,使用成员初始化列表的构造函数将覆盖相应的类内初始化。

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分