cppTest-8.2:虚析构函数探究&父类和子类的构造函数与析构函数的调用顺序

/**
 *cppTest-8.2:虚析构函数探究&父类和子类的构造函数与析构函数的调用顺序
 *
   @@总结:
  构造函数调用顺序:
  基类->子类->子类的子类......

  析构函数调用顺序:
	基类<-子类<-子类的子类......
 *author 炜sama
 */
#include<iostream.h>
class color{
public:
	//构造函数不能定义为虚函数!
	color(){cout<<"color()"<<endl;}
	//@@如果这里的释放函数不是虚函数,那么对于delete p[0]、delete p[1]、delete p[2],
	//都只调用color的释放函数,因为p[i]是color类指针。
	//这将导致实际为red和bright_red类对象编写的释放函数没有得到正确的调用而不能释放它们的类对象。
	virtual ~color(){cout<<"~color()"<<endl;}
};
class red:public color{
public:
	red(){cout<<"red()"<<endl;}
	~red(){cout<<"~red()"<<endl;}
};
class bright_red:public red{
public:
	bright_red(){cout<<"bright_red()"<<endl;};
	~bright_red(){cout<<"~bright_red()"<<endl;};
};
void main()
{
	color *p[3];
	cout<<"新建对象,观察构造函数的调用顺序:"<<endl;
	//@@1构造函数调用顺序为从最基类到子类!!!
	p[0]=new red;
	p[1]=new bright_red;
	p[2]=new color;
	
	cout<<"删除对象,观察析造函数的调用顺序:"<<endl;
	//@@虚析构函数调用顺序与上面相反!!!
	delete p[0];//在调用color的释放函数前调用red的释放函数
	delete p[1];//在~color()和~red()调用前调用~bright_red()
	delete p[2];//调用~color()
	//如果把父类的虚析构函数的virtual去掉,上面的情况就完全不同了:只会调用color的析构函数!

	cout<<"red对象指针指向red对象的情况"<<endl;
	red *r=new red;//同@@1
	delete r;//不管父类析构函数是否为虚函数,这里的效果都不变:从子类到父类的顺序调用析构函数。可见虚析构函数主要在多态时起作用!
}

C++ 的测试框架通常会使用桩函数(Stub)来模拟被测对象的行为,以便在测试中进行隔离和控制。对于一些常见的函数,cpptest 可以自动生成桩函数,从而简化测试的编写过程。下面是 cpptest 如何自动生成桩函数的示例: 假设我们有一个计算器类 Calculator,其中包含一个 `add()` 方法用于计算两个整数的和。我们想要测试这个方法,但是它依赖于另外一个类的方法,因此我们需要使用桩函数来模拟这个方法的行为。 ```c++ class Calculator { public: Calculator(Adder* adder) : adder_(adder) {} int add(int a, int b) { return adder_->add(a, b); } private: Adder* adder_; }; class Adder { public: virtual ~Adder() {} virtual int add(int a, int b) = 0; }; class RealAdder : public Adder { public: int add(int a, int b) override { return a + b; } }; ``` 在使用 cpptest 进行测试时,我们可以使用 `CPPTEST_AUTO_STUB` 宏来自动生成桩函数。这个宏会根据被测函数的参数类型和返回值类型自动生成一个桩函数,并且将其添加到测试代码中。 ```c++ TEST(CalculatorTest, AddTest) { // 自动创建桩函数 CPPTEST_AUTO_STUB(int, Adder::add, (int a, int b), (a, b), (0)); // 模拟 Adder::add() 方法 Adder* adder = new AdderStub(); EXPECT_CALL(*adder, add(2, 3)).WillOnce(Return(5)); // 测试 Calculator::add() 方法 Calculator calculator(adder); EXPECT_EQ(calculator.add(2, 3), 5); } ``` 在这个示例中,我们使用 `CPPTEST_AUTO_STUB` 宏来自动生成 Adder::add() 方法的桩函数,这个桩函数的返回值类型为 int,参数类型为两个 int 类型的参数。在测试中,我们模拟了 Adder::add() 方法的行为,并且测试了 Calculator::add() 方法的正确性。 总的来说,使用 cpptest 自动生成桩函数可以简化测试代码的编写过程,提高测试的效率和可靠性。但是需要注意的是,自动生成的桩函数可能无法满足所有的测试需求,需要在实际使用中加以验证和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值