简单地说,您如何在C++中为单级继承创建接口(interface)(出于简单性和教学原因)?我看到一些代码没有使用多态性,但是基类包含一个虚拟抽象方法(virtualvoidTheMethod()=0)。现在用纯虚方法从这个抽象类派生出一个类,但是在后面的代码中,使用派生类的实例完全没有动态分配。这是正确的做法吗?使用多态设计推断出的开销又如何呢?我认为这是不可能的。这看起来更像是隐藏/重影基本方法,即使该方法是纯虚拟方法也是如此。稍后编辑:感谢所有设法提供一些好的答案的人,我想强调一个严重的错误,该错误是由于使用“动态分配”而引起的,其含义是强调这一点对象创建的可能性是唯一与多态性兼
我想在子类中存储静态字符串,这样它们就不会在内存中重复。可以这样做吗?我希望能够实例化两个IBM,但只将字符串“IBM”放入内存中一次。classCompany{staticconststd::stringcompany_name;}classCocaColaCompany:publicCompany{staticconststd::stringcompany_name="CocaCola";}classIBM:publicCompany{staticconststd::stringcompany_name="IBM";}或者在多态基类中使用静态成员有问题吗?
自从几年前我发现了CRTP以来,我在很多地方都使用它来为非常密集的面向计算的代码实现编译时多态性。当一个人关心运行时的通用性和最大性能时,以通用方式将成员函数“注入(inject)”到类中是很棒的。我在conceptslite上阅读/观看了几件事这将是(我希望)下一个C++标准的一部分。以更抽象和通用的方式设计功能绝对很棒,避免了我目前使用的SFINAE/std::enable_if的糟糕行。我还没有测试过实现概念的g++分支来玩弄它们,并以一种新的方式研究我喜欢的元编程方法。但也许你们中的一些人有。我的第一个想法是概念不会解决静态多态性的问题,但由于这类事情可能严重依赖技巧,我可能是
如果我想在C++中克隆一个多态对象(即从其他类B派生的类A的实例),最简单的方法似乎是给B一个虚拟克隆成员函数,它必须被覆盖A看起来像这样A*clone(){returnnewA(*this);}我的问题是,我发现这种不必要的样板代码,因为如果想使用C++的运行时多态特性,这几乎总是需要的。如何规避?谢谢为什么我需要这个:我的用例可以抽象为以下示例:我有一个classIntegral,它计算某个函数的积分。这样做,他们有一个成员,它是指向classMathFunction的指针。这个抽象类包含一个纯虚函数evaluate,它接受一个参数。我想实现幂函数,我将创建一个classPowFu
多态性和运算符重载混合在一起了吗?没有指针就无法实现多态性,如thisanswer中所述。而且你不能像解释的那样用指针重载运算符here.所以真的没有办法做到这一点,对吧? 最佳答案 是的。您没有正确阅读答案。这是一个简短的演示:#includeusingnamespacestd;structX{intvalue;virtualvoidoperator+=(intx){value+=x;}};structY:X{virtualvoidoperator+=(intx){value*=x;}};voiddo_stuff(X&x){x+=
我正在保存一堆不同的对象并将它们重新加载到一个文件中,这些对象都是从一个公共(public)基础派生的,显然我需要存储类名(或类似的东西)以便在重新加载时创建正确的对象类型。保存很容易:classBase{virtualstringclassName()const=0;voidsaveToFile(){write(className());...otherwritingstuff}}classDerived1:publicBase{stringclassName()const{return"Derived1";};...}classDerived2:publicBase{stringc
我有C++代码:intmain(){M*m;O*o=newIO();H*h=newH("A");if(__rdtsc()%5==0){m=newY(o,h);}else{m=newZ(o,h);}m->my_virtual();return1;}虚拟调用由这个asm表示:movrax,qwordptr[x]movrax,qwordptr[rax]movrcx,qwordptr[x]callqwordptr[rax]这比我预期的vtable方法调用多了一行。所有四个ASM行都特定于多态调用吗?上面四行怎么伪读?这是完整的ASM和C++(虚拟调用在最后进行):intmain(){addby
所以我有这些类(class)。有一个基类,但它有/将会有很多很多派生类,而这些派生类也将能够有派生类。我希望能够拥有一个将二进制数据写入文件的函数,但我不确定如何对大量派生类执行此操作。我在想一些事情:voidwriteData(ofstream&_fstream){_fstream.write()//etc..}但是每个实现此方法的派生类都必须写入其父类的所有数据,这将重复大量代码。在不重写所有以前编写的writeData()代码的情况下,最好的方法是什么? 最佳答案 您可以从派生类实现中调用基类实现:voidDerived::w
请看下面的代码list:#includeusingnamespacestd;classBase{public:virtualvoidMessage()=0;};classIntermediate:publicBase{};classFinal:publicIntermediate{voidMessage(){coutMessage();*///Works:Intermediate*finalPtr=&final;//orBase*finalPtr=&final;finalPtr->Message();return0;}注意以下事项:在抽象Base类中,纯虚函数message()是pub
我正在尝试构建一个通用算法。到目前为止,我已经使用类层次结构和指针实现了这一点,如下例所示:structBase{virtualdoublefn(doublex){return0;}};classDerived:publicBase{doubleA;public:Derived(doublea):A(a){}doublefn(doublex){returnA*x;}};//Someotherimplementationsclassalgo{doubleT;std::unique_ptrb_ptr;public:algo(doublet,std::unique_ptr&_ptr);//m