在派生类中缺少静态成员变量时强制编译错误
Force compilation error on missing static member variable in derived classes
假设以下类层次结构:
//file base.h
class IBase
{
public:
virtual ~IBase() = default;
//a static member identifying IBase (e.g. "iid.base")
static const char* const IID; //initialize in implementation file
//[...]
};//class IBase
class IDerived : public IBase
{
public:
virtual ~IDerived() = default;
//a static member identifying IDerived (e.g. "iid.derived")
static const char* const IID; //initialize in implementation file
//[...]
};//class IDerived
class IEvenMoreDerived : public IDerived
{
public:
virtual ~IEvenMoreDerived() = default;
//missing static const member IID!
//[...]
};//class IEvenMoreDerived
此层次结构中的每个类都必须有自己的static const tChar* const iid
可用于标识对象而无需实例化它。在IEvenMoreDerived
缺少此信息。
现在,在代码的某个地方,我有一个访问 IID 的函数模板:
//file main.cpp
#include "base.h"
template<typename T>
void queryIID()
{
std::cout << T::IID << std::endl;
}
int main(int argc, char* argv[])
{
queryIID<IBase>(); //prints "iid.base"
queryIID<IDerived>(); //prints "iid.derived"
queryIID<IEvenMoreDerived>(); //probably prints "iid.derived"
return 0;
}
我的目的是在使用queryIID<IEvenMoreDerived>();
时出现编译时错误,因为IEvenMoreDerived
没有静态成员iid
。我认为有可能在函数模板queryIID()
中使用一些模板魔术,但我尝试的所有方法都没有解决问题。
一些补充要点:
- 不幸的是,使用
constexpr char*
而不是static const char* const
似乎是不可能的,因为根据MS VS2015功能预览,即使在VS2015中也不会受到支持。 - 经过一番挖掘,我遇到了C++模板常见问题解答。据此,成员隐藏是类模板的"功能"。我只是想不通如何使用它来解决我的问题。此外,我不希望将上面介绍的类层次结构更改为类。
- 在其他问题中,我在 SO 上发现了这个有点相似的问题,但它并不完全符合我的问题。
作为一种解决方法,您可以在外部结构中委派Id
,如下所示:
template <typename T>
struct IdName
{
static const char* const IID;
};
// instead of `const char* const IBase::IID = "IBase";`
// you have to use the following
template <> const char* const IdName<IBase>::IID = "IBase";
// Same for IDerived
template <> const char* const IdName<IDerived>::IID = "IDerived";
尝试使用IdName<IEvenMoreDerived>::IID
时出现链接错误。
现场示例
相关文章:
- std::is_base_of表示ctor编译错误
- Qt5:使用QCommandLineParser类时出现奇怪的编译错误
- 如何修复sfml c++代码编译错误
- 使用 MATLAB 编码器生成C++代码:编译错误"undefined reference to `rgb2gray_tbb_real64'"
- 使用外部SDK工具链文件在VisualStudio上生成项目编译错误
- vscode下的Arduino代码出现意外编译错误
- 第三方 API 中的编译错误 - Visual Studio
- std::cout输出int时出现编译错误
- 奇怪的代码抛出编译错误模板< J,int aSize=10> C2143:语法错误:在"<"之前缺少";"
- 提升图广度优先搜索前置编译错误
- C++ 中的编译错误:未定义对"主"的引用 collect2:错误:ld 返回 1 个退出状态
- 使用带有 ref 参数的成员函数创建线程时出现编译错误
- 我在C++中遇到了这个奇怪的编译错误
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- 使用 std::enable_if 限制派生类的模板参数时出现编译错误
- 现代OpenGL和GLEW Libraray的编译错误
- C++ 编译错误:意外的类型名称"字符串":预期的表达式
- C ++程序编译错误,找不到/访问文件
- 使用直接大括号初始化时,C++ 编译错误"声明末尾的预期";"
- 为什么传递非静态成员函数会导致编译错误?