《Effective C++》念书条记09:毫不在结构和析构进程中挪用virtual函数
首先明晰一下,对付一个担任体系,结构函数是从基类开始挪用了,而析构函数则正 好相反,从最外层的类开始。
对付在结构函数中挪用virtual函数,先举个例子:
1 class Transaction //所有生意业务的基类
2 {
3 public:
4 Transaction();
5 virtual void logTransaction() const = 0;//日志记 录,因生意业务范例的差异而有差异的记录
6 }
7
8 Transaction::Transaction()//结构函数实现
9 {
10
11 logTransaction();//挪用了日志记录
12 }
13
14 class Sell: public Transaction
15 {
16 public:
17 virtual void logTransaction() const;
18
19 }
Sell类从基类中担任,这时候假如执行:
1 Sell a; //派生类
则首先会执行Transaction的结构函数,而Transaction结构函数会挪用Transaction版 本的logTransaction函数(记着:基类结构函数中的virtual函数不会下降到派生类中) 。
而各人都知道,基类中的logTransaction还没有实现代码,这显然会发生一个毗连错 误。
有如下的办理要领:将logTransaction声明为非virtual函数,然后通过派生类向基类 通报参数的要领来实现。
1 class Transaction
2 {
3 public:
4 Transaction (const std::string& logInfo);
5 void logTransaction(const std::string& logInfo) const;//改成非virtual实现
6
7 };
8
9 Transaction::Transaction(const std::string& logInfo)
10 {
11
12 logTransaction(logInfo);//同样在结构函数中挪用
13 }
14
15 class Sell: public Transaction
16 {
17 public:
18 Sell()
19 :Transaction(createLog())//将log信息传给基类结构函 数
20 {
21
22 }
23 }
如此一来,就是派生类将结构信息向上传给基类结构函数,办理了这个问题。