C++继承与多态(二)

来源:互联网 发布:linux mrtg定制 编辑:程序博客网 时间:2024/05/26 22:10
多态
       虚函数:类成员函数前面加virtual关键字
       虚函数重写:当在子类的定义了一个与父类完全相同的虚函数时,则称子类的这个函数重写了这个父类的这个虚函数
       满足条件
       1.虚函数的重写
       2.父类的指针/引用调用虚函数
       多态跟类型无关,与对象有关


       多态:当使用基类的指针或引用调重写的虚函数时,当指向父类调用的就是父类的虚函数,指向子类调用的就是子类的虚函数。父类必须写上虚函数。
       总结
       1. 派生类重写基类的虚函数实现多态,要求函数名、参数列表、返回值完全相同。(协变除外
       2.基类中定义了虚函数,在派 类中该函数始终保持虚函数的特性。
       3.只有类的成员函数才能定义为虚函数。
       4.静态成员函数不能定义为虚函数。
       5.如果在类外定义虚函数,只能在声明函数时加virtual,类外定义函数时不能加virtual
       6.构造函数不能为虚函数,虽然可以将operator=定义为虚函数,但是最好不要将operator=定义为虚函数,因为容易使用时容易引起混淆。
       7.不要在构造函数和析构函数里面调用虚函数,在构造函数和析构函数中,对象是不完整的,可能会发生未定义的行为。
       8.最好把基类的析构函数声明为虚函数。(因为派生类的析构函数跟基类的析构函数名称不一样,但是构成覆盖,这里是因为编译器做了特殊处理)


       纯虚函数:在成员函数的形参后面写上=0,则成员函数为纯虚函数。包含纯虚函数的类叫做象类(也叫接口类),抽象类不能实例化出对象。纯虚函数在派生类中重新定义以后,派生类才能实例化出对象。
class Person{  virtual void Display () = 0; // 纯虚函数 protected :  string _name ; // 姓名};class Student : public Person{};
       友元与继承友元关系不能继承,也就是说基类友元不能访问子类私有和保护成员。
class Person{  friend void Display ( Person & p , Student& s );protected :  string _name ;// 姓名};class Student : public Person{protected :  int _stuNum ;// 学号};void Display ( Person& p , Student & s){  cout <<p . _name<< endl ;  cout <<s . _name<< endl ;  cout <<s . _stuNum<< endl ;}void TestPerson1 (){  Person p;  Student s;  Display (p, s);}
       继承与静态成员:基类定义了static成员,无论派生出多少个子类,整个继承体系中只有这样static一个成员。