软件开发|编程技术|编程代码|编程入门先学什么—程序设计语言

C++类中一个构造函数调用另一个构造函数

class A  {      int a;      int b;      int c;  public:      A(int aa, int bb) : a(aa), b(bb),c(0)  { cout  "aa bb"  endl; }      A(int aa, int bb, int cc);  };  
上面类中,已经有一个构造函数,形参有两个,我们又重载一个有3个形参的构造函数,为了减少代码量,就想着让3个参数的构造函数调用2个参数的构造函数,然后在执行一些自己的代码,这就如同派生类先调用基类的同名函数,在执行自己特有的代码。这种机制如何实现呢?


做法一:在3个参数中显示调用2个参数的构造函数(这肯定是可以的, 构造函数是类的成员函数),此时要用到placement new技术。

3参数构造函数可以这样实现:


[cpp] view plain copy A::A(int aa, int bb, int cc)   {      new (this) A(aa, bb);      ...  }  构造函数有2个执行阶段:1)是在初始化列表的初始化阶段;2)在构造函数体内的赋值阶段。上述方法是在第二个阶段。placement new技术的形式是 new(void *p) Type(...),表示在p所指的内存区域调用Type构造函数,该过程没有内存请求。上述实现有“投机取巧”之嫌,就是在对象地址处,调用2个参数的构造函数重新生成一个新的对象然后覆盖该对象。


做法二:在VS2013中发现可以在构造函数初始化列表直接调用,类似于调用基类构造函数。该方法在g++中不适合。


[cpp] view plain copy A::A(int aa, int bb, int cc) :A(aa, bb)  {      ...  }  上述说了构造函数有2个执行阶段,该方法是在第一个阶段进行的,这种方式有点类似C#里面的机制,更加方便。该方法有个注意事项是不能在A(aa, bb)后面在接c(cc)了,因为调用2个参数的构造函数之后,就相当于该对象已经初始化完成了,不能在初始化列表放入其他成员的初始化形式。只能放在构造函数体中的赋值阶段。该方法目前只能用在VS2013中。


做法二有很大的局限性,不过确实很方便。不知标准文档对于构造函数互相调用有怎样的规定?是否以后其他编译器会加入该功能?