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.基类的指针也可以指向基类对象,也可以指向派生类对象。