《Effective C++》念书条记09:毫不在结构和析构进程中挪用virtual函数
当前位置:以往代写 > C/C++ 教程 >《Effective C++》念书条记09:毫不在结构和析构进程中挪用virtual函数
2019-06-13

《Effective C++》念书条记09:毫不在结构和析构进程中挪用virtual函数

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

如此一来,就是派生类将结构信息向上传给基类结构函数,办理了这个问题。

    关键字:

在线提交作业