该程序的运行结果让我傻眼了,结果输出a的值不确定。为什么在默认构造函数中调用另一个构造函数确没有改变a的值呢???后来才明白,其实A(11)是调用另一构造函数并产生一临时变量,而不是去用另一构造函数去构造默认构造函数。
1)在c++里,由于构造函数允许有默认参数,使得这种构造函数调用构造函数来重用代码的需求大为减少。
2)如果仅仅为了一个构造函数重用另一个构造函数的代码,那么完全可以把构造函数中的公共部分抽取出来定义一个成员函数(推荐为private),然后在每个需要这个代码的构造函数中调用该函数即可。
3)偶尔我们还是希望在类的构造函数里调用另一个构造函数,可以按下面方式做:
在构造函数里调用另一个构造函数的关键是让第二个构造函数在第一次分配好的内存上执行,而不是分配新的内存,这个可以用标准库的placement new做到。
先看看标准库中placement new的定义
inline void *__cdecl operator new(size_t, void *_P)
{
return (_P);
}
调用上述的函数没有分配新的内存,这正是我们想要的。因此我们可以这样在一个构造函数里调用另一个构造函数:
注: 若构造函数调用自身,则会出现无限递归调用,是不允许的。一般按上文中第二点编写代码。
另外:如果要正确调用自身的构造函数,应该这样写:
这样调用就能够产生正确的结果
本文探讨了C++中一个类的构造函数如何错误地尝试调用另一个构造函数导致不可预期的结果,并给出了正确的做法,包括使用placement new及推荐的做法。
882

被折叠的 条评论
为什么被折叠?



