雕虫小技

如何得到constructor 和 copy constructor 执行次数

DarkSpy 于 2002/6/24

我们知道,编译器在构造一个对象的时候,需要调用 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
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<
cout<}

我们再来增加一点代码,再做个试验。

在 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<}

有人要问,为什么要写 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 的结束。
本站文章仅代表作者观点,本站仅传递信息,并不表示赞同或反对.转载本站点内容时请注明来自-Linux伊甸园。如不注明,将根据《互联网著作权行政保护办法》追究其相应法律责任。

--------------------next---------------------