最赞回答 / qq_闭眼爱幻想_0
<...code...>因为你定义的是Shape类型的指针,Shape类里面的函数不虚,就被调用了。Shape中的函数被定义成虚函数才能生成虚函数列表指向子类的虚函数。
2016-09-12
最新回答 / SkyWalker_1
当然,一下只是个人观点。本人是小白,接受各位dalao的批判。前提是你用父类对象去实例化子类。如果没有virtual,则不生成虚函数表指针,则只能找到父类的成员函数。如果加上virtual后,会生成,并且可以通过此函数表找到子类的虚函数指针,继而找到子类的虚函数。
2016-09-10
最新回答 / 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
最新回答 / 慕粉3744161
虚析构函数适用于如下这种情况:如果用new运算符开辟了一端空间,如果基类中有析构函数,且定义了一个指向该基类的指针变量。如果在释放这段内存时,只执行基类析构函数,而不执行继承类析构函数,就会造成内存泄漏,所以要采用虚析构函数。
2016-08-05