Я преобразовывал некоторые из своих математических классов в шаблоны и использовал списки инициализации, и столкнулся с проблемой, когда унаследованному классу необходимо получить доступ к элементам данных базового класса при инициализации.
Вот код:
template <typename T>
struct xCoord2
{
T x;
T y;
xCoord2(T _x, T _y) : x(_x), y(_y) {};
};
template <typename T>
struct xCoord3 : xCoord2<T>
{
typedef xCoord2<T> B;
T z;
// All Error
xCoord3(T _x, T _y, T _z) : x(_x), y(_y), z(_z) {};
xCoord3(T _x, T _y, T _z) : B::x(_x), B::y(_y), z(_z) {};
xCoord3(T _x, T _y, T _z) : this->x(_x), this->y(_y), z(_z) {};
// Works
xCoord3(T _x, T _y, T _z) { B::x = 0; B::y = 0; z = 0; };
};
Можно ли использовать списки инициализации для унаследованных классов?
xCoord3
являетсяxCoord2
? Или они просто разделяют определенные элементы данных? Это тот случай, когда наследование не может быть хорошей идеей, если между двумя классами нет отношения «есть». - person James McNellis   schedule 27.01.2011