这篇文章运用简单易懂的例子给大家介绍C++中多态公有继承的实现方法,代码非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
方法的行为应取决于调用该方法的对象。这种较复杂的行为称为多态——具有多种形态,即同一个方法的行为随上下文而异。
virtual实现了对象调用正确的方法或方法序列。
实现多态的两种机制:
声明函数时若使用关键字virtual,则这些方法被称为虚方法。
class Brass {private: ...public: ... virtual void ViewAcct() const; virtual ~Brass(){} }
BrassPlus :
基类声明了一个虚构函数,是为了确保释放派生对象时,按正确的顺序调用析构函数(后面见虚函数作用)。
Brass dom("Dominic Banker", 11224, 4183.45); BrassPlus dot("Dorothy Banker", 12118, 2592.00); dom.ViewAcct(); // use Brass::ViewAcct()dot.ViewAcct(); // use BrassPlus::ViewAcct()
两个ViewAcct()原型表明将有2个独立的方法定义。基类版本的限定名为Brass::ViewAcct(),派生类版本的限定名为BrassPlus::ViewAcct()。
通过引用或指针而不是对象调用方法:
如果没有使用关键字virtual,程序将根据引用类型或指针类型选择方法:
// behavior with non-virtual ViewAcct()// method chosen according to reference typeBrass &b1_ref = dom; Bross &b2_ref = dot; b1_ref.ViewAcct(); // use Brass::ViewAcct()b2_ref.ViewAcct(); // use Brass::ViewAcct()
如果要在派生类中重新定义基类的方法,通常应将基类方法声明为虚的。这样,程序将根据对象类型而不是引用或指针的类型来选择方法版本。为基类声明一个虚析构函数也是一种惯例,使用虚析构函数可以确保正确的析构函数序列被调用(即从派生类对象到基类对象一次调用它们的析构函数)。
调用基类方法:在派生类方法中,标准技术是使用作用域解析运算符来调用基类方法:
Brass::ViewAcct(); // display base portion
关于C++中多态公有继承的实现方法就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。