Я пытаюсь обеспечить различные статические инициализации для классов в иерархии, но когда я попытался с этим кодом:
#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 *, единственная проблема с этим, я как бы надеялся выполнить инициализацию для частичных специализаций, и, похоже, нет никакого способа, которым я знаю о том, чтобы переопределить только одну функцию в частичной специализации, не копируя весь другой код, который останется в основном таким же