草庐IT

c++ - 在 C++ 中查找紧密成员函数名称

我刚刚遇到了一个错误(我自己造成的!),表现如下。我有一个带有虚拟成员函数的类,我需要通过为一些新用例添加一个额外的参数来扩展它。我用默认值添加了它,这样它就不会中断任何当前调用。我错过的是,还有另一个类继承自此类,该类具有对该函数的覆盖,但不再是覆盖。虽然我知道override关键字来避免在添加新代码时出现这种情况,我想知道是否有任何方法可以找到词法上足够接近的所有函数,从而可能出现类似的错误。曾经做过一次,我有可能在过去的某个时间做过,并且想回顾性地检查代码库。 最佳答案 Clang有警告标志-Woverloaded-virtu

C++ 重载 virtual = 运算符

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

c++ - [C++]协变返回类型

我有一个VectorN类和一个继承自VectorN的Vector3类(例如,它可以处理叉积)。我无法确定不同运算符的返回类型。示例:classVectorN{public:VectorN(){};virtualVectorNoperator*(constdouble&d){.....};std::vectorcoords;};classVector3:publicVectorN{public:Vector3(){};virtualVector3operator*(constdouble&d){....};};此特定示例产生C2555错误:'Vector3::operator*':ove

c++ - 将特定的 gcc 警告变成错误

所以我知道我可以使用-Werror=...将警告变成错误,但我想将以下警告变成错误:“类xxx有虚函数但非虚析构函数”据我所知,您遇到此错误的唯一方法是打开过于讨厌的-Weffc++标志。有没有一种方法(或者-Weffc++中这个警告的子标志是什么)只打印这个警告然后把它变成一个错误?谢谢! 最佳答案 -Wnon-virtual-dtor是-Weffc++开启的特定警告名称。要将任何警告变成错误,您可以使用-Werror=...。因此,如果警告是-Wspam,则将其变成错误将是-Werror=spam。所以在这种情况下,您将使用-W

c++ - std::vector 类型引用的无效初始化

这是错误:DummyService.hpp:35:error:invalidcovariantreturntypefor'virtualstd::vector>&DummyService::list(conststd::string&)'classBean{public:typedefstd::stringPath;virtual~Bean(){};virtualconstPath&getPath()=0;virtualconststd::string&getName()=0;protected:Bean();};classResourceBean:publicBean{public:

c++ - 抽象类继承另一个具有相同函数名的抽象类

classsubscriber{public:virtualvoidupdate()=0;}classentity:publicsubsriber{public:virtualvoidupdate()=0;}classmyObject:publicentity{public:virtualvoidupdate(){do_things();}}subscriber*ptr=newmyObject;//willuseshared_ptr,buthereiwantsimplicityptr->update();问题是,是否会调用正确的更新函数(在myObject中实现的函数)?在一个“家族”

c++ - 虚构造函数以及在其中调用虚函数会发生什么

我有两个问题,我在这里找到的答案并不完全令我满意:为什么将构造函数声明为虚函数毫无意义?当我从构造函数调用虚函数时会发生什么?虚表也用上了吗? 最佳答案 Whydeclaringaconstructorasvirtualismeaningless?在构造函数执行之前,对象不存在,所以不存在覆盖这样的东西。WhathappenswhenIcallavirtualfunctionfromaconstructor?Isthevirtualtableusedtoo?可以。在大多数情况下,如果直接从构造函数执行调用,编译器可以跳过动态分派(d

c++ - error LNK2019 未解析的外部符号虚拟类

我知道这个问题被问过好几次了,但我找不到解决方法。我在尝试构建我的项目时遇到此错误:errorLNK2019:unresolvedexternalsymbol"public:virtual__thiscallIGameState::~IGameState(void)"(??1IGameState@@UAE@XZ)infunction"public:virtual__thiscallMenuState::~MenuState(void)"(??1MenuState@@UAE@XZ)这是我的代码:IGameState.hclassIGameState{public:virtual~IGam

c++ - 如果从构造函数/析构函数中不加限定地调用虚函数,是否会发生虚分派(dispatch)?

structA{virtual~A(){f();}virtualvoidf(){}};我已将我的问题编辑得更具体..在此代码示例中,调用f()可以使用虚拟分派(dispatch),还是保证等同于A::f()?您能否提供C++标准中的相关部分?谢谢。 最佳答案 在构造函数或析构函数中,子类对象要么尚未构造,要么已经被销毁。因此,虚拟分派(dispatch)不会导致使用派生类版本,而是调用基类版本。根据标准,[class.cdtor]/4:Memberfunctions,includingvirtualfunctions(10.3),c

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

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