当前位置:首页 > 芯闻号 > 充电吧
[导读]class A   {       int a;       int b;       int c;   public:       A(int aa, int bb) : a(aa), b(bb),

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中。


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


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭