草庐IT

virtual-keyboard

全部标签

C++ 重载 virtual = 运算符

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

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++ - 多层继承中的virtual关键字

我有一个继承链,其中A类公开继承自B类,B类又公开继承自C类。C类的析构函数被标记为“虚拟”。是否有人反对将B类和A类的析构函数标记为虚拟的?或者在这些情况下是否需要支付性能/内存损失? 最佳答案 如果基类析构函数被标记为虚拟的,那么派生类析构函数也是隐式虚拟的,您不需要明确地将其指定为虚拟的。没有性能或内存损失所以在你的例子中,如果C有一个虚拟析构函数B并且A继承了析构函数的“虚拟性” 关于c++-多层继承中的virtual关键字,我们在StackOverflow上找到一个类似的问题:

c++ - C++ 中 `virtual` 关键字对对象而不是指针的行为

我试图理解虚函数。考虑以下代码,#include#include#includeclassAnimal{public:virtualvoideat(){std::cout使用virtual关键字我得到了输出Ieatlikeagenericanimal.Ieatlikeawolf!这是应该的。但是如果我删除virtual关键字,我仍然会得到相同的输出!从我的对虚函数的基本理解,没有virtual我应该得到输出Ieatlikeagenericanimal.Ieatlikeagenericanimal.这里有什么我遗漏的基本知识吗?我在Linux上使用g++编译器

c++ - 函数声明中缺少 'virtual' 限定符

在浏览一些旧代码时,我遇到了类似于以下内容的内容:classBase{public:virtualintFunc();...};classDerived:publicBase{public:intFunc();//Missing'virtual'qualifier...};代码编译良好(MSVS2008),没有警告(级别4)并且按预期工作-Func是虚拟的,即使派生类中缺少虚拟限定符。现在,除了引起一些困惑之外,这段代码是否有任何危险,或者我是否应该全部更改它,添加virtual限定符? 最佳答案 virtual将被传递到派生类中的

c++ - 为什么 virtual 关键字会增加派生类的大小?

我有两个类-一个基类和一个派生类:classbase{inti;public:virtual~base(){}};classderived:virtualpublicbase{intj;};main(){cout这里的答案是16。但是如果我改为非虚拟公共(public)继承或使基类成为非多态的,那么我得到的答案是12,即如果我这样做:classbase{inti;public:virtual~base(){}};classderived:publicbase{intj;};main(){cout或classbase{inti;public:~base(){}};classderived