C++中指向派生类指针问题
比如说定义了一个父类father和一个子类son继承父类father然后定义指针fatherp=newson;这时指针p是指向father还是son?这句话我觉得有点乱,...
比如说定义了一个父类father和一个子类son继承父类father
然后定义指针 father p=new son; 这时指针p是指向father 还是son? 这句话我觉得有点乱,可以给我解释下吗?它有什么应用 展开
然后定义指针 father p=new son; 这时指针p是指向father 还是son? 这句话我觉得有点乱,可以给我解释下吗?它有什么应用 展开
2个回答
展开全部
先看两个知识点:
1.C++中基类和派生类遵循类型兼容原则:
即可用派生类的对象去初始化基类的对象,
可用派生类的对象去初始化基类的引用,
可用派生类对象的地址去初始化基类对象指针。
2.C++中动态绑定条件发生需要满足2个条件:
(1)只有指定为虚函数的成员函数才能进行动态绑定,成员函数默认为非虚函数,非虚函数不能进行动态绑定
(2)必须通过基类类型的引用或指针进行函数调用
father *p=new son即是用son初始化了一个father类指针(类型兼容原则第三条);
多态(动态绑定)的实现靠的就是虚函数,一个类有虚函数,则有虚表,father有father的虚表,son有son的虚表,用一个vptr指针标记虚表入口。若father里有虚函数fun,son重写fun函数,则p->fun实际调用的是son中的fun,若son未重写fun,则调用father中的fun;这就是多态(动态联编);
1.C++中基类和派生类遵循类型兼容原则:
即可用派生类的对象去初始化基类的对象,
可用派生类的对象去初始化基类的引用,
可用派生类对象的地址去初始化基类对象指针。
2.C++中动态绑定条件发生需要满足2个条件:
(1)只有指定为虚函数的成员函数才能进行动态绑定,成员函数默认为非虚函数,非虚函数不能进行动态绑定
(2)必须通过基类类型的引用或指针进行函数调用
father *p=new son即是用son初始化了一个father类指针(类型兼容原则第三条);
多态(动态绑定)的实现靠的就是虚函数,一个类有虚函数,则有虚表,father有father的虚表,son有son的虚表,用一个vptr指针标记虚表入口。若father里有虚函数fun,son重写fun函数,则p->fun实际调用的是son中的fun,若son未重写fun,则调用father中的fun;这就是多态(动态联编);
展开全部
p当然是指向son了,new谁就指向谁,否则还叫指针么~~
不过如果father有虚函数,则对象的内存会有个虚函数表,如果son重写了虚函数,那么通过指针调用father的虚函数,实际上在虚函数表转了个弯跑son的实现里去了。
不过如果father有虚函数,则对象的内存会有个虚函数表,如果son重写了虚函数,那么通过指针调用father的虚函数,实际上在虚函数表转了个弯跑son的实现里去了。
追问
意思说假如father里有虚函数f,则调用p->f 时是调用father类中的f ?那如果想调用son类的f 呢?还有“通过指针调用father的虚函数实际上在虚函数表转了个弯跑son的实现里去了“是什么意思
追答
p->f系统会判断,p具体指向的是son还是father,如果是son,那么调用的是son的f,如果son没有重写f则系统调用son的父类的f,否则调用son的f
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询