已采纳回答 / qq_倩你一生_04232347
#include "Worker.h"#include <iostream> Worker::Worker(string n,int a):Person(n){ Age=a;}void Worker::work(){ //cout<<Name<<" is "<<Age<<endl; cout<<"work--worker"<<endl;}少加了下划线的地方
2016-10-31
已采纳回答 / 慕后端7037387
我认为是这样,类的成员函数都在代码区,不同的类的成员函数在代码区有自己的类名称空间限制,类的虚函数在虚函数表中,程序执行的时候,是先在虚函数表中找该成员函数,如果没有找到,就去该类在代码区的成员函数中去找。所以如果父类的成员函数加上virtual时,访问的时候是先在虚函数表中查找,如果找到了,就执行,没找到就再在该类的代码区查找。所以父类普通的成员函数只能在父类的代码区找到。也就是说通过父类指针找普通成员函数时,虽然父类指针指向子类对象,通过父类指针只能访问子类对象的数据成员(部分,父类独有的),不能访问...
2016-10-22
最新回答 / BE_YOUSELF
这里是会有隐藏,但是你在父类中的同名成员函数前加了virtual,会生成一个虚函数表,定义的指针是通过虚函数表来只想要调用的函数。只理解到这里,见谅!
2016-09-06
最赞回答 / 慕后端7037387
视频中已经实例化了:(1)Circle *cir=new Circle(3,5,40);Shape *shape1 = cir;(2)Shape *shape1 = new Circle(3,5,4.0);之间的区别只是子类对象有没有子类指针指向;题主(1)应该是想说子类对象有了子类指针指向的话,就可以利用删除子类指针来调用子类析构函数了,所以第二种做法非要再加上virtual虚析构函数,就是多此一举;其实,在使用的时候,我们用父类指针指向子类对象,什么时候结束使用该指针,如果使用(1),则要delete...
2016-09-05