private virtual函数

派生类可以继承基类中的private virtual函数

《Effective c++》上说:“derived class可重新定义继承而来的private virtual函数”。
这个规则可以用到NVI手法中。
“令客户通过public non-virtual成员函数间接调用private virtual函数,称为non-virtual
interface(NVI)手法。它是所谓Template Method设计模式的一个独特表现形式。我把这个non-virtual函数称为virtual函数的外覆器。……这意味着外覆器可以确保得以在一个virtual函数被调用之前设定好适当场景,并在调用结束之后清理场景。……NVI手法涉及在derived class内重新定义private virtual函数。……derived class可重新定义继承而来的private virtual函数”

class GameCharacter
{
public:
    int healthValue() const; // 在基类中定义non-virtual函数,在private virtual函数中实现可变算法。在non-virtual函数中调用virtual函数,保证处理的顺序。

private:
    virtual int doHealthValue() const; // 可变的算法写到private virtual中。
};

int GameCharacter::healthValue() const
{
    cout<<"计算健康值前的处理……"<<endl;
    int retVal = doHealthValue();
    cout<<"计算健康值后的处理……"<<endl;
    return retVal;
}

int GameCharacter::doHealthValue() const
{
    cout<<"默认的健康值计算方式"<<endl;
    return 0;
}

class GameCharacterA : public GameCharacter
{
private:
    int doHealthValue() const; // 在派生类中只要重写基类中的private virtual中就可以了。
};

int GameCharacterA::doHealthValue() const
{
    cout<<"角色A的健康值计算方式"<<endl;
    return 0;
}

void main()
{
    GameCharacter* gc = new GameCharacterA();
    gc->healthValue();
}

收藏于 2013-12-20

来自于百度空间

时间: 2024-10-11 19:17:13

private virtual函数的相关文章

《Effective C++》:条款35:考虑virtual函数以外的其他选择

条款35:考虑virtual函数以外的其他选择 条款35考虑virtual函数以外的其他选择 藉由Non-virtual Interface手法实现Template Method模式 藉由Function Pointers实现Strategy模式 藉由tr1function完成Strategy模式 古典的Strategy模式 摘要 virtual函数在派生中经常用到,在遇到一些问题时用virtual函数没问题,但是有时候我们应该思考一下是否有替代方案,以此来拓宽我们的视野. 假如现在正在写一个游

Effective C++ Item 35 考虑 virtual 函数以外的实现

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie 1.virtual 函数版本 class GameCharacter{ public: virtual int healthValue() const; //返回人物的健康指数, derived classes 可重新定义它 }; 2.使用 non-virtual interface 手法,那是 Template Method 设计模式的一种特殊形式. 让客户通过 public non-v

Effective C++ 条款35 考虑virtual函数以外的其他选择

1. 在一个继承层次中,不同的类要实现同一接口的不同实现,最先想到的可能是虚函数,假设一个存在一个继承体系,这个集成体系中的每一层都需要一个名为fun函数,那么可能会像这样实现: clase Base{ public: ... virtual fun(int num){...} private: ... } class Derived:public Base{ public: ... virtual fun(int num){} private: ... } 但除了将fun设为虚函数,还有其他选

Effective C++笔记_条款35 考虑virtual 函数以外的其他选择

因为其他的事情耽误了看书,现在将看的笔记记录下来. 1 class GameCharacter { 2 public: 3 virtual int healthValue() const; 4 }; 1. 藉由Non-Virtual Interface 手法实现 Template Method模式 (1)non-virtual interface(NVI): 令客户通过public non-virtual 成员函数间接调用private virtual函数 (2) virtual 函数的外覆器(

Effective C++:条款35:考虑virtual函数以外的其他选择

游戏中的人物伤害值计算问题. (一)方法(1):一般来讲可以使用虚函数的方法: class GameCharacter { public: virtual int healthValue() const; //返回人物的体力值,派生类可以做出修改 ... }; 这确实是一个显而易见的设计选择.但因为这样的设计过于显而易见,可能不会对其它可选方法给予足够的关注.我们来考虑一些处理这个问题的其它方法. (二)方法(2):使用NVI方法,在基类中使用一个公有的普通函数调用私有的虚函数. class G

Effective C++_笔记_条款09_绝不在构造和析构过程中调用virtual函数

(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) 为方便采用书上的例子,先提出问题,在说解决方案. 1 问题 1: class Transaction{ 2: public: 3: Transaction(); 4: virtual void LogTransaction() const = 0 ; 5: ... 6: }; 7:  8: Transaction::Transaction() //Base cl

effective c++ 条款09:绝不在构造和析构过程中调用virtual函数

记住:在构造和析构期间不要调用virtual函数,因为这类调用从不下降至derived class. class Transaction { //所有交易的base class public: Transaction(); virtual void logTransaction() const = 0; //做出一份因类型不同而不同的log }; Transaction::Transaction() { ... logTransaction(); } class BuyTransaction:

条款09:绝不在构造和析构过程中调用virtual函数

在base构造期间virtual函数不是virtual函数,因为构造函数首先从base构造函数开始执行,执行的时候继承类的对象并没有也就无从调用其成员函数,用以下这种方式能解决问题: 上面的做法,在要对继承类使用构造函数的时候通过参数传递给base构造函数. 注意:

Effective C++ .37 virtual函数中默认参数的表现

#include <iostream> #include <cstdlib> using namespace std; class Pen { public: virtual void write(int color = 0) { cout<<"write with color:"<<color<<endl; } }; class Pencil : public Pen{ public: void write(int colo