C++ 多态公有继承 即希望同一个方法在派生类和基类中的行为是不同的。换句话来说,方法的行为应取决于调用该方法的对象。这种较复杂的行为称为多态–具有多种形态,即同一个方法的行为随上下文而异。有两种重要的机制可用于实现多态公有继承: 1. 在派生类中重新定义基类的方法。 2. 使用虚方法。
以下中基类为Brass, 派生类为:BrassPlus
class Brass
{
public:
virtual void withdraw(double amt);
virtual void ViewAcct() const;
virtual ~Brass();
}
class BrassPlus
{
public:
virtual void withdraw(double amt);
virtual void ViewAcct() const;
void ResetMax(double n);
}
1.基类中的方法加vitual声明为虚函数,在派生类中使用关键字vitual来指出哪些函数是虚函数也不失一个好办法。 2. 在基类中声明了一个虚析构函数。这样做是为了确保释放派生对象时,按正确的顺序调用析构函数。 3. 虚函数的使用:如果方法是通过引用或指针而不是对象调用的,它将确定使用哪一种方法。如果没有使用关键字vitual,程序将根据引用类型或指针类型选择方法;如果使用了vitual,程序将根据引用或指针指向的对象的类型来选择方法。 如果viewAcct()不是虚的,则程序的行为如下: Brass dom(“Dominic Banker”, 11224, 4183.45); BrassPlus dot(“Dorothy Banker”, 12118, 2592.00);
Brass& b1_ref = dom; // dom,dot是对象调用
Brass& b2_ref = dot;
b1_ref.ViewAcct(); // use Brass:: ViewAcct()
b2_ref.ViewAcct(); // use Brass:: ViewAcct()
如果viewAcct()不是虚的,则程序的行为如下: Brass dom(“Dominic Banker”, 11224, 4183.45); BrassPlus dot(“Dorothy Banker”, 12118, 2592.00);
Brass& b1_ref = dom; // dom,dot是对象调用
Brass& b2_ref = dot;
b1_ref.ViewAcct(); // use Brass:: ViewAcct()
b2_ref.ViewAcct(); // use BrassPlus:: ViewAcct()
这里两个引用类型都是Brass, 但是b2_ref引用的是一个BrassPlus对象,所以使用的是BrassPlus::ViewAcct()。 4.基类的指针也可以指向基类对象,也可以指向派生类对象。
|