假设以下课程:
struct X : A, B, C{};
如果我将其更改为以下内容,可能会出现什么问题?
struct indirect_C : C{};
struct indirect_BC : B, indirect_C{};
struct X : A, indirect_BC{};
这个例子可能看起来很人为,但是当你通过可变参数模板继承可变数量的碱基时,它也会发生,并且还希望在派生类中提供(或不提供)这些碱基的功能。
template<class... List>
struct X : List...{
using List::something...; // ill-formed in C++11
};
因此,您需要一种解决方法,即“递归地”继承并在每个递归步骤中将功能纳入范围:
template<class Head, class... Tail>
struct inherit_indirect
: Head
, inherit_indirect<Tail...>
{
using Head::something;
using inherit_indirect<Tail...>::something;
};
template<class T>
struct inherit_indirect<T>
: T
{
using T::something;
};
(参见例如this answer of mine,我使用了这种技术。)
答案 0 :(得分:2)
您无法在X的构造函数中直接初始化类基础对象B和C.