Я пытаюсь предоставить различные статические инициализации для классов в иерархии, но когда я попытался использовать этот код:
#include <iostream>
using namespace std;
struct base {
static const char* componentName;
};
const char* base::componentName = "base";
struct derived : public base {};
const char* derived::componentName = "derived";
int main() {
cout << base::componentName << endl;
cout << derived::componentName << endl;
}
, я получил следующую ошибку сборки:
test.cpp:15: error: ISO C++ does not permit ‘base::componentName’ to be defined as ‘derived::componentName’
test.cpp:15: error: redefinition of ‘const char* base::componentName’
test.cpp:11: error: ‘const char* base::componentName’ previously defined here
Кажется, что статические инициализации нельзя переопределить в производных классах? Если это не сработает, я всегда могу определить componentName как статическую функцию, которая возвращает const char *, единственная проблема с этим я как бы надеялся выполнить инициализацию для частичных специализаций, и, похоже, нет никакого способа, чтобы я знаю, как переопределить только одну функцию в частичной специализации, без копирования всего остального кода, который останется в основном таким же