当我从基本构造函数调用虚函数时,编译器不会给出任何错误。但是当我从基类构造函数调用纯虚函数时,它会出现编译错误。考虑下面的示例程序:#includeusingnamespacestd;classbase{public:voidvirtualvirtualfunc()=0;//voidvirtualvirtualfunc();base(){virtualfunc();}};voidbase::virtualfunc(){coutvirtualfunc();return0;}这里可以看出纯虚函数是有定义的。我希望在执行bptr->virtualfunc()时调用基类中定义的纯虚函数。相反,
我正在研究C++中virtual关键字的效果,我想出了这段代码。#includeusingnamespacestd;classA{public:virtualvoidshow(){coutshow();ac->show();bc->show();}预期的输出是:BCB因为B中的show函数是非虚拟的。但是编译时的结果是:BCC它的行为就好像B中的show函数是虚拟的。为什么会这样?B类在这里被覆盖了吗?如果我将C类指向B类,我怎么会指向A类? 最佳答案 根据C++2017标准(10.1.2函数说明符)2Thevirtualspeci
我有一个C++模块需要从其他类获取信息,但不知道这些类。显而易见的方法是使用接口(interface)。让我举个例子。假设我有一个管理图书的图书馆,所有的图书都有自己的特性和功能,而要让图书馆从一本书中获取一个特性或执行一个功能,这本书需要实现一个接口(interface)。像这样:classLibrary{public:voidaddBook(IBook&book);};classIBook{public:stringgetAuthor()=0;stringgetTitle()=0;stringgetISBNCode()=0;size_tgetNofPages()=0;size_tg
假设我有类Base和Derived:publicBase。我已经使用boost::interprocess库构建了一个共享内存段。是否有可能有类似这样的代码:Base*b=newDerived();write(b);//oneappwritesBase*b2=read(b);//secondappreads//bequalsb2(bitwise,nottheptrlocation)我在这里看到的问题是,例如Base的派生类所需的空间是未知的(那么要分配多少shmem?)问:如何在应用程序之间通过指针传递对象? 最佳答案 只需阅读其d
如何控制虚拟表中虚拟函数的顺序?它们的排列顺序是否与声明的顺序相同?当继承一个带有虚表的类时,被继承类的虚表是基类的扩展,还是只用继承类的虚函数创建的全新虚表。(即虚拟表是否仍在类的索引+0x0处?) 最佳答案 (a)就标准而言,你不能,(事实上你甚至不能假设vtables存在)。(b)可能吧,但是在什么情况下你需要控制顺序,但是你自己查不到呢?检查的方法是查看虚拟调用的反汇编(并找到添加到vtable指针的偏移量以获得调用地址)或查看vtable本身的反汇编。视情况而定。对于单继承,可能它是基类的扩展,每个对象的索引0指向该类的一
尝试搜索,没有返回(我认为)。是否可以制作一个抽象类的vector?例如,我有父类(superclass)Unit。我有士兵、车辆和轰炸机子类。但是我想要一个vector中的任何子类的实例,例如vectorUnitList可以包含士兵和车辆的实例吗?这可能吗?如果有帮助,我会使用C++。 最佳答案 是的,但是您需要使用指针或智能指针(我会选择这个)。structX{virtual~X(){}//a;a.push_back(newY);a[0]->foo();for(inti=0;i不要忘记删除分配的内存。为什么不能使用实际对象:假设
将所有虚函数构造为私有(private)或protected基类接口(interface)是有充分理由的(参见this)。但是,如何防止派生类(可能在外部客户手中)将私有(private)虚函数设为公共(public)呢?在VirtuallyYours,作者讨论了这个问题,但没有讨论解决方案。编辑:根据您的回答和我之前的想法,似乎没有办法阻止这种情况。但由于在这种情况下,很容易出错(客户端肯定会触及protected虚函数),编译器对这种用法发出警告是有道理的。我试着用g++测试它。首先,我写道:classA{protected:virtualvoidnone(){return;}};
我看到了下面的代码片段:classFoo{public:voidvirtualfunc()throw(int,float)=0;};classBar:publicFoo{public:voidvirtualfunc()throw(short);//line1:compileerror"//looserthrowspecifier"voidvirtualfunc()throw();//line2:cancompilevoidvirtualfunc()throw(float,int);//line3:cancompilevoidvirtualfunc()throw(float);//lin
在C++tutorialsininternet之一中,我发现了以下关于为什么构造函数不能是虚拟的描述Wecannotdeclareavirtualconstructor.Weshouldspecifytheexacttypeoftheobjectatcompiletime,sothatthecompilercanallocatememoryforthatspecifictype.这个描述是否正确?我对这个短语特别感到困惑:以便编译器可以分配该特定类型的内存。 最佳答案 正如Bjarne自己在他的C++StyleandTechniqu
我的问题是引用thisquestion这解释了虚函数在对象切片的情况下如何工作,最终调用基类虚函数和Wikipediaarticle这解释了下面代码的派生类的虚拟表布局classA{public:virtualvoidfunc(){cout以上程序输出“InA::func”。但是如果B类的虚表不知道基类A::func怎么会最终调用A::func 最佳答案 AoA=*ptr1;这会将任何成员变量复制到一个新的A对象中。vtable指针不是普通成员变量,不会被复制。因此,针对此对象调用的任何后续虚函数都将作为A对象,因为它是A对象。