草庐IT

C++:虚拟继承

全部标签

c++ - 虚拟方法 C++

我面临以下问题。我实现父类-Vehicle,它有一些派生类,其中之一-FastVehicle。在程序中,我需要存储Vehicle*指针的Vector。指针也可以指向Vehicle对象或FastVehicle对象。1)我希望能够为vector中的每个对象调用方法print()。问题是,在FastVehicle的情况下,我还想将一个参数传递给函数,我需要调用带有签名的函数:voidprint(inta)我对虚函数机制了解一点,但据我所知,只有当两个函数具有相同的签名时它才有效。我想听听关于如何解决的建议。2)此外在派生类FastVehicle中还有一些独特的功能,它不与父类Vehicle共

c++ - clang/g++ 与私有(private)继承和使用声明的区别

考虑以下代码:#includestructParams{};templatestructBase{intdata()const{return42;}};templateclassD,classP>structMiddle:privateD//mustbe'public'forg++{};structFinal:publicMiddle{usingBase::data;};intmain(){Finalf;std::cout此代码编译成功并打印42clang并在gcc上给我编译时错误'intBase::data()const[withT=Params]'isinaccessible在这种

c++ - 了解空继承类的未使用 typedef

我只是想了解我正在阅读的一些教程代码。我正在尝试学习一些Dx11代码,我正在学习的教程中包含设计为事件详细信息的类,以便在事件发生时传递给函数,例如鼠标按钮被按下。有一个空的基类EventArgs定义如下:classEventArgs{public:EventArgs(){};}这是由其他事件类继承的。因此,例如,他们有一个按键事件参数类,如下所示:classKeyEventArgs:publicEventArgs{public:typedefEventArgsbase;KeyEventArgs(/**/){}//Restoftheclass}我理解所有事件都继承一个基础来表示“它们是

c++ - 在继承的构造函数中仅 move 类参数

以下代码无法编译GCC6.1,但适用于Clang3.8.0和VisualStudio2015:#includeclassbase{public:base(std::unique_ptr){}};classderived:publicbase{public:usingbase::base;};intmain(){deriveddf(std::make_unique());}出现以下错误:main.cpp:Inconstructor'derived::derived(std::unique_ptr)':main.cpp:10:17:error:useofdeletedfunction'st

c++ - 虚继承中构造函数的调用顺序是怎样的?

c++虚继承中构造函数的调用顺序是怎样的?针对下面两种多重继承的情况;(I)对于下面的代码,没有虚继承;classa{public:a(){cout输出是:ababcabcdef(II)类e虚继承:classa{public:a(){cout输出是:abcabcdeabf谁能解释一下这两种情况下的输出是如何获得的?虚继承如何影响对象的构造? 最佳答案 首先初始化虚基类,否则直接基类按照基类声明从左到右的顺序初始化。对于类f,classf:publicb,publice,没有虚基类,直接基类b会是首先初始化,然后是e。(从左到右的顺序

c++ - boost optional 承认继承?

classBase{};classDerived:publicBase{};voidfunc(boost::optional&){}intmain(){boost::optionalx;func(x);}func会接受两个可选值:base和derived吗? 最佳答案 不,它不会起作用。func对boost::optional取一个左值引用.这意味着它可以接受boost::optional类型的左值。,一个从boost::optional公开且明确派生的类型的左值,或具有operatorboost::optional&()的其他类型

c++ - 虚拟继承是否增加开销

假设我有这个类:classA{};这个派生类:classB:publicvirtualA{};然后没有任何东西从B派生。声明Bvirtual是否会增加不需要的开销? 最佳答案 我认为虚拟继承可能需要少量的额外开销,尽管这可能取决于编译器如何实现非虚拟继承。普通继承可以通过简单地将派生类的成员连接到基类来实现(类似于将基类作为派生类的第一个成员)。访问基类的成员是从对象开头的简单偏移量,就像访问派生类的成员一样。但是对于虚拟继承,必须通过指针进行间接寻址。这允许所有从同一个基类虚拟继承的类都有指向基类共享数据的指针。因此访问基类的成员

c++ - 为继承 enable_shared_from_this 的类获取 unique_ptr

通常我更喜欢从工厂返回unique_ptr。最近我遇到了为继承enable_shared_from_this的类返回unique_ptr的问题。此类的用户可能会意外调用shared_from_this(),尽管它不属于任何shared_ptr,这会导致std::bad_weak_ptr异常(或C++17之前的未定义行为,通常作为异常实现)。代码的简单版本:classFoo:publicenable_shared_from_this{stringname;Foo(conststring&_name):name(_name){}public:staticunique_ptrcreate(c

如何在Azure的特定虚拟机上创建应用程序服务?

我正在为Azure创建应用程序服务。应用服务正在使用自己的IP地址。如何在Azure的特定虚拟机上创建应用程序服务。看答案在公共应用服务环境中,您不能。(使用AppService的一部分是您不必担心VM)如果您真的需要,那么应用程序服务环境。它使您可以在虚拟网络中创建自己的环境。这是一种高级产品(非常昂贵),但它允许您控制公共IP地址。

c++ - 使用 protected 非虚拟析构函数时抑制 delete-non-virtual-dtor 警告

我有一个纯抽象接口(interface)类和一个实现该接口(interface)的派生类。structFoo{virtualvoiddoStuff()=0;};structBar:Foo{voiddoStuff()override{}};我的接口(interface)类没有虚拟析构函数。因此,尝试使用基类指针破坏派生实例显然是未定义的行为intmain(){Foo*f=newBar;f->doStuff();deletef;}幸运的是我的编译器足够聪明,可以捕捉到这个(使用-Werror)main.cc:15:9:error:deletingobjectofabstractclasst