草庐IT

virtual-destructor

全部标签

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

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

c++ - C++ 中的虚拟析构函数与普通方法

考虑以下三个C++程序:节目1structbase{virtual~base()=0;};structderived:publicbase{~derived();};derived::~derived(){}intmain(){}节目2structbase{virtual~base()=0;};structderived:publicbase{~derived(){}};intmain(){}节目3structbase{virtualvoidfunc()=0;};structderived:publicbase{voidfunc();};voidderived::func(){}int

C++ 重载 virtual = 运算符

这是我的问题的代码:classICommon{public:virtualICommon&operator=(constICommon&p)const=0;};classCSpecial:publicICommon{public:CSpecial&operator=(constCSpecial&cs)const{//customoperationsreturn*this;}};CSpecialobj;基本上:我希望接口(interface)ICommon强制其后代实现=运算符,但不希望在实现中有任何类型转换。编译器说“无法实例化抽象类。任何帮助/建议将不胜感激。

c++ - 从具有非虚拟父类的虚拟类继承的正确方法

我编写了这个使用三种类型的测试代码:structOne是一个没有虚成员的普通类型,structTwo:One有一个纯虚函数和一个虚拟析构函数,structThree:Two实现了Two的接口(interface)。#includestructOne{~One(){std::couttest();One*one=two;deleteone;}不出所料,theoutputwas这个:Three::test()~One()除了让每个析构函数都成为虚拟函数之外,还有什么办法可以解决这个问题吗?或者程序员应该小心不要遇到这种情况?我觉得很奇怪,编译时没有警告。 最佳答

c++ - 'non-virtual interface' 和 'abstract interface' 有什么区别?

我正在用C++实现设计模式,我希望我的类通过组合来利用接口(interface),这让我研究了实现接口(interface)的不同方法。我想澄清一下这个术语的定义。 最佳答案 非虚拟接口(interface)是一个公共(public)成员函数,它不是虚拟的,但通常希望根据可覆盖的虚拟函数来实现:classInterface{public:intcompute(){returncompute_impl();}private:virtualintcompute_impl()=0;protected:virtual~Interface()

c++ - 如果没有类重新实现 'virtual' 关键字是否可以优化掉?

当我在C++中定义一个类时,我总是将dtor定义为虚拟的。这是我在编写继承类时保护自己的方法。我想知道我是否要支付性能开销,即使我不会继承该类。例如:classAfinal{A();virtual~A(){printf("dtor");}};当我使用这个类时,dtor实际上是通过vtable调用还是作为静态dtor实现? 最佳答案 WhenIdefineaclassinC++Ialwaysdefinethedtorasvirtual.这是非常糟糕的做法。类应该被设计成多态的……或者不是。这也不仅仅是设计问题——多态性增加了开销。现在

c++ - 为什么必须将 "virtual"放入基类而不是仅在子类中使用 "override"?在 C++ 中

标题几乎说明了一切。为什么要在基类中定义以后可能重写的函数?如果您想从中派生出不同行为的版本,那么您必须修改基类,并且您还没有考虑过将基类中的特定函数标记为虚拟。据我所知,您通过使用override解决了java中的此类抽象定义,这对我来说似乎更自然(尽管到目前为止我只关注java)。c++中的这种扭曲是为了强制程序员提前思考,还是有技术原因导致它这样工作? 最佳答案 这样做是为了使成员函数成为虚函数的决定保留在基类中。决定将一个函数设为虚函数会对设计产生影响:如果你将一个函数设为虚函数,你必须考虑它执行不同操作的可能性。相反,您可

c++ - "virtual base class in the case of multilevel inheritance"有意义吗

考虑以下显示多级继承的示例代码:案例1:这里类derived1是通过虚拟继承从类base派生的,类derived2是从类派生的直接类derived1。classbase{};classderived1:virtualpublicbase{};classderived2:publicderived1{};Case2:与Case1相同,只是不涉及虚拟继承classbase{};classderived1:publicbase//novirtualinheritance{};classderived2:publicderived1{};假设我在这两种情况下都创建了derived2类的对象。C

c++ - 为什么 virtual void test()=00 有效但 virtual void test()=+0 和 virtual void test()=-0 无效?

我搜索了一些关于虚函数声明的帖子,相信=0在virtualvoidtest()=0;是固定句法所以virtualvoidtest()=NULL;virtualvoidtest()=false;virtualvoidtest()=1-1;virtualvoidtest()=0.0;和其他声明应该是无效的。但是我发现了virtualvoidtest()=00;virtualvoidtest()=000;virtualvoidtest()=0000;还能编译,为什么?还有,我觉得整数+0和-0其实和0一样(不知道对不对),就像00其实就是0一样,为什么virtualvoidtest()=+0

c++ -/boost/lockfree/queue.hpp: 错误: 静态断言失败: (boost::has_trivial_destructor<T>::value)

我正在尝试替换boost::lockfree::queue对于std::queue在这个文件中https://github.com/zaphoyd/websocketpp/blob/experimental/examples/broadcast_server/broadcast_server.cpp我添加了#include;改线130,std::queuem_actions;,至boost::lockfree::queuem_actions;;删除所有与锁定有关的行;并更改了行103,m_actions.pop();,至m_actions.pop(a);.我在sconsbroadcas