如何得到constructor和copy constructor执行次数
DarkSpy @ 2002/6/24 @ http://coneos.126.com
我们知道,编译器在构造一个对象的时候,需要调用 constructor,如果程序员本身没有定义constructor,在某种状况下则编译器会给你合成一个,如果我们的对象具有了memberwise 语意的时候,则编译器将会给你合成一个 operator= 和 copy constructor,编译器会进行 data member 的 copy 操作,作为一些不太知道C++内部运作的程序员来说,如何知道copy constructor执行了几次了呢?
不要企图使用简单的 int 来累加 constructor 和 copy constructor,如果 int 变量在类里面,则在constructor的时候就构造了一次,destructor的时候就析构掉了,就无法得出正确的执行次数,或许你会说:我可以把 int 定义为全局变量啊,试试看,我们绝对无法得出一个对象调用了几次constructor和copy constructor,而且数字出现偏差。
那该怎么办?
我们可以先定义一个简单的类,里面定义专有的操作,例如++操作符,和简单的constructor,
#include <iostream.h>struct C{int count;C():count(0) {}int operator++(int) { return count+=1; } // 重载++运算符};
OK,定义好了这个基础的 count 类之后,我们可以开始我们的constructor试验。
我们首先定义一个叫 X 的类,里面定义constructor和copy constructor,在里面,利用前面定义的count类来进行累加数字:
class X{friend class C;public:C ct;X():ct(*new C) { ct++;} // constructor,初始化 ct 并开始累加X(const X &o) { ct = o.ct; ct++;}// copy constructor,将copy constructor 中 ct 的结果拷贝到 ct 中并累加};
我们开始吧
main(){X x;X a=x; X b=a; cout<<b.ct.count; /* 得到的这个数字就是对象 b 的 constructor 和 copy constructor 执行的次数 */
cout<<x.ct.count; /*就是对象 x 的constructor和copy constructor执行的次数*/}
我们再来增加一点代码,再做个试验。
在 class X 后,我们再增加一个 X 的函数:
X func(X &_this){return _this;}
无疑,这个函数也会调用 copy constructor,那么怎么得到他的次数呢?
main(){X x;X a=x; X b=a;int i = func(b).ct.count;cout<<i; /* 这个 i 就是用了 func 函数后得到的 constructor 和 copy constructor 执行的次数 */}
有人要问,为什么要写 int i = func(b).ct.count; 而不直接写:func(b).ct.count; ?
因为 func 是一个类型为 X 的函数,而这个函数是要调用 copy constructor 的,而这个调用是在 return _this 之后,所以如果直接写:func(b).ct.count; 将会少一次累加,所以利用一个 int i 将得到完全执行完毕的 func 函数调用的 constructor 和 copy constructor。
在 X 类里面,我们友元了类 C,C 的对象 ct 在 X 对象构造的时候初始化,然后开始累加,ct 的生命周期将保持到类 X 的结束。
2002/6/24