jjzjj

virtual-inheritance

全部标签

c++ - 如何解决 : undefined reference to `non-virtual thunk to ...`

我正在尝试弄清楚如何进一步解决此问题。我还想知道如何安装更新版本的ld(如果有意义的话)。所有涉及的包管理器都告诉我,我是最新的。代码在ubuntu12.04和12.10上使用g++(4.7.2)编译、链接和运行,但在FC17上编译失败并出现此错误。ArchiveServiceLib/debug-posix/libArchiveLib.a(NamedIflTiffCache.o):(.rodata._ZTV26UnlockingGenericFileHandle[_ZTV26UnlockingGenericFileHandle]+0x58):undefinedreferenceto`I

C++ : noexcept (or throw()) virtual destructor = default;

下面的代码是合法的吗?classC{virtual~C()noexcept=default;};或classC{virtual~C()throw()=default;};(throw()已弃用,但我的编译器不支持noexcept;;) 最佳答案 8.4.2[dcl.fct.def.default]Anexplicitly-defaultedfunction[...]mayhaveanexplicitexception-specificationonlyifitiscompatible(15.4)withtheexception-spe

c++ - 视觉 C++ 14 CTP3 : c++11 inheriting constructor bug?

以下代码片段在Clang3.4/3.5(Xcode5/6)下构建完美,但在VisualC++14CTP3下抛出错误:1>------Buildstarted:Project:InheritingConstructor,Configuration:DebugWin32------1>inheritingconstructor.cpp(60):errorC2661:'D::D':nooverloadedfunctiontakes2arguments==========Build:0succeeded,1failed,0up-to-date,0skipped==========代码确实通过尝

C++虚方法的虚继承

structA{virtualvoidfoo(){std::cout所以这个在编译时给了我们以下错误:\main.cpp:16:8:error:nouniquefinaloverriderfor'virtualvoidA::foo()'in'D'structD:publicB,publicC{如果我们让B和C结构的继承成为非虚拟的,代码正在编译就没有任何错误(当然,如果我们调用dd.foo()).那么有什么区别呢?为什么我们虚拟继承我们的类会出错,而直接继承却不会出错? 最佳答案 使A成为B和C的虚拟基类确保D恰好包含一个A子对象[

c++ - 虚拟基类的创建顺序

我有以下问题:structA1{A1(){std::cout当您运行这段代码时,答案是:A1A2A1AA2A2AA1B我想了解第一个A1是在哪里创建的。我知道虚拟类在非虚拟类之前调用​​的规则,但第一个A1是困扰我的问题。 最佳答案 第一个A1来自B的(非虚拟)基AA1的(虚拟)基的初始化。首先初始化B的所有虚基,依次为A1、A2和AA2。(AA2的初始化导致输出A1AA2。)然后是直接基,其中只有一个,AA1(其初始化打印A2AA1),最后是类本身,打印B。首先是所有虚拟基地,然后才是剩余的非虚拟基地。

c++ - 没有虚拟继承的奇怪行为

这个问题在这里已经有了答案:multipleinheritance:unexpectedresultaftercastfromvoid*to2ndbaseclass(3个答案)关闭5年前。我正在处理一段表现出非常奇怪行为的代码。我设法在一个简单的helloworld风格的程序中复制了它,代码如下:#includeusingnamespacestd;classTest{public:virtual~Test()=default;protected:virtualvoidSetUp(){}};classICallbackReceiver{public:virtual~ICallbackRe

c++ - 虚拟继承中类的大小

使用虚拟继承时类的大小如下..ABase=4(sizeofimem)BBase=12(sizeofimem+ABase+VBase_ptr)CBase=12(sizeofimem+ABase+VBase_ptr)这是有道理的,但我不明白为什么ABCDerived的大小是24。classABase{intiMem;};classBBase:publicvirtualABase{intiMem;};classCBase:publicvirtualABase{intiMem;};classABCDerived:publicBBase,publicCBase{intiMem;};

c++ - 有没有办法将 "inherit"设为 int 等基类型?

我有几个与此类似的结构:structTime64{int64_tMilliseconds;Time64operator+(constTime64&right){returnTime64(Milliseconds+right.Milliseconds);}...blahblahallthearithmeticoperatorsforcalculatingwithTime64andint64_twhichisassumedtorepresentmillisecondsstd::stringParse(){fancytextoutput}}现在我需要添加更多它们。本质上它们只是对任何基类的解

c++ - 为什么不调用虚拟基础非默认构造函数,除非大多数派生基础显式调用它们?

我想了解为什么C++标准要求虚拟基础非默认构造函数不能由非最派生的中间体调用类,如此代码中所示,当使用“-D_WITH_BUG_”编译时:/*Avirtualbase'snon-defaultconstructorisNOTcalledUNLESS*theMOSTDERIVEDclassexplicitlyinvokesit*/#include#include#includeclassA{public:int_a;A():_a(1){std::cerr因此,当编译时没有-D_WITH_BUG_,代码打印:$g++-I.-std=gnu++17-mtune=native-g3-fPIC-

c++ - 通常方法上的 Woverloaded-virtual 警告

我很困惑为什么下面的代码会产生Woverloaded-virtual警告。classTestVirtual{public:TestVirtual();virtualvoidTestMethod(inti);};classDerivedTestVirtual:publicTestVirtual{public:voidTestMethod();};派生类具有不带参数的常用方法TestMethod-签名不同于基类的类似虚拟方法。那为什么编译器不能解决这种情况呢? 最佳答案 警告的原因是无参数版本从基类中隐藏了int版本。DerivedTe