虚函数与多态知识点总结

虚函数和多态

1:多态性是指一个名字,多种语义;或界面相同,多种实现。

2:虚函数允许函数调用与函数体的联系在运行时才进行,称为动态联编。

3:实现运行时多态的关键首先是要说明虚函数,另外,必须用类指针调用派生类的不同实现版本

4注意点:

①:一个虚函数,在派生类层界面相同的重载函数都保持虚特性

 ②:虚函数必须是类的成员函数

 三:不能将友元说明为虚函数,但虚函数可以是另一个类的友元

 ④:析构函数可以是虚函数,但构造函数不能是虚函数。

5:虚函数的重载特性:

①:在派生类中重载基类的虚函数要求函数名、返回类型、参数个数、参数类型和顺序完全相同

 ②:如果仅仅返回类型不同,C++认为是错误重载。如果函数原型不同,仅函数名相同,丢失虚特性

6:虚析构函数:

①:构造函数不能是虚函数。建立一个派生类对象时,必须从类层次的根开始,沿着继承路径逐个调用基类的构造函数

②:析构函数可以是虚的。虚析构函数用于指引 delete 运算符正确析构动态对象

7构造函数、内联成员函数、静态成员函数不能是虚函数。

8析构函数可以是虚函数,通常声明为虚函数。

9:纯虚函数和抽象类:

纯虚函数是一种特殊的虚函数,在许多情况下,在基类中不能对虚函数给出有意义的实现,而把它声明为纯虚函数,它的实现留给该基类的派生类去做。

二:典型代码:

#include
using namespace std ;
class  Base
{ public :       Base(char xx)  { x = xx; }
                      void who()  { cout << "Base class: " << x << "\n" ; }
   protected:    char x;
} ;
class  First_d : public  Base
{ public :       First_d(char xx, char yy):Base(xx)  { y = yy; }
                      void who()  { cout << "First derived class: "<< x << ", " << y << "\n" ; }
   protected:    char y;
} ;
class  Second_d : public  First_d
{ public :
      Second_d( char xx, char yy, char zz ) : First_d( xx, yy ) { z = zz; } 
      void who()  { cout << "Second derived class: "<< x << ", " << y << ", " << z << "\n" ; }
   protected:    char z;
} ;
int main()
{ Base  B_obj( 'A' ) ;   First_d F_obj( 'T', 'O' ) ;  Second_d S_obj( 'E', 'N', 'D' ) ;
   Base  * p ;
   p = & B_obj ;    p -> who() ;
   p = &F_obj ;     p -> who() ;
   p = &S_obj ;     p -> who() ;
   F_obj.who() ;
   ( ( Second_d * ) p ) -> who() ;
}

你可能感兴趣的:(虚函数与多态知识点总结)