c++多态是基于虚函数实现的,具体怎么实现的下面详细说一下,
只要有虚函数存在就会存在一张虚函数表,就是个数组,用来存放虚函数的入口地址,说简单点就是一个函数指针数组表,下面说下在继承中如果父类存在虚函数,,便会创建这张表,将父类的虚函数按找声明顺序填入,因此虚函数表的地址是在定义对象时才确立的。所以使用父类的指针指向子类的对象时,如果父类中存在虚函数且子类将虚函数重写,则先将父类的虚函数表复制到该子类的虚函数表中,将子类的虚函数表中存放的函数地址(未重写前存放的是子类的虚函数的函数地址)更新为重写后函数的函数指针。子类如果要将继承自父类的虚函数重写的话,那么虚函数列表中的虚函数就会被覆盖,如果子类添加父类没有的虚函数,会按顺序添加在虚函数表的后面
父类指针调用一个虚函数时默认调用的Fptr指向子类虚函数表中的重写后的虚函数地址所对应的虚函数。
虚函数的入口地址和普通函数有什么不同?
每个虚函数都在vtable中占了一个表项,保存真一条跳到它的入口地址的指令(实际上就是保存了它的入口地址)。当一个包含虚函数的对象(注意,不是对象的指针)被创建的时候,它在头部附加了一个指针,指向vtable中相应的位置。
调用虚函数的时候,不管你是用什么指针调用,它先根据vtable找到入口地址再执行,从而实现了“动态联编”。
普通函数只是简单的跳到一个固定的地址。
虚函数实现多态的优缺点?
优点:复用性强 扩展性强
缺点:安全性差(拿到对象的地址便可访问函数)浪费空间。