函数的重载是多态性的一种简单体现。普通成员函数的重载可以在类中说明重载,也可以基类的成员函数在派生类中进行重载。有三种的编译区分方法(具体的再查资料呗)。同时C++还提供一种灵活的多态性机制:虚函数。虚函数允许,函数调用与函数体的联系,在运行时候才进行。被称为动态联编。所谓的动态联编是指编译程序在编译阶段并不能确切地知道将要调用的函数,只有在程序执行时才能确定将要调用的函数,为此要确切地知道将要调用的函数,要求联编工作在程序运行时进行。虚函数是动态联编的基础。所以先介绍下派生类的指针再介绍下虚函数。
派生类的指针:
指向基类和派生类的指针是相关的。例如:A *P;//对象指针 A a;//A的对象 B b//B类的对象 P=&a;//P指向对象a
P=&b;//指向b对象(假设B从A中公有继承)则P可以通过b访问所有从a继承的元素,但是不能用P访问b对象自身特定的元素(除非用显式类型转换)。举个例子吧……
#include <iostream>
using namespace std;
class A
{
private:
char name[20];
public:
void put_name(char *s){strcpy(name,s);}
void show_name(){cout<<name<<"\n";}//<<endl;}//看下这个效果呢?
};
class B:public A
{
private:
char phone_num[80];
public:
void put_phone(char *num){strcpy(phone_num,num);}
void show_phone(){cout<<"phone num is "<<phone_num<<"\n";}
};
void main()
{
A *p;A a;//p为基类指针,p为对象指针
B *bp;B b;
a.put_name("俞飞鸿");//为什么这个可以通过呢?
a.show_name();
cout<<"========================"<<endl;
p=&a;p->put_name("吴镇宇");p->show_name();
p=&b;p->put_name("李安");p->show_name();//通过对象b访问从A中继承的元素
a.show_name();b.show_name();
cout<<"号码的显式"<<endl;
bp=&b;bp->put_phone("5555555");
bp->show_phone();
((B*)p)->show_phone();//用基类的指针访问公有派生类的特定成员,必须进行类型转换
}
本来p是基类的指针,只能通过对象b访问从A中继承的元素,但是通过指针类型的转换后,将其转换为B类指针,则可以访问派生类中的其他成员。
一个基类的指针是可以指向从基类公有派生的任何对象。此为C++运行时,多态的关键途径。但是不能用指向派生类的指针指向一个基类对象。