将可变模板链接在一起

Chaining variadic templates together

本文关键字:链接 在一起      更新时间:2023-10-16

如果以下代码中的X被转换为使用C++11可变模板,并且应该支持任意数量的模板参数,它会是什么样子?

template<int OFFSET>
struct A { enum O { offset = OFFSET }; enum S { size = 2 }; };
template<int OFFSET>
struct B { enum O { offset = OFFSET }; enum S { size = 4 }; };
template<int OFFSET>
struct C { enum O { offset = OFFSET }; enum S { size = 10 }; };
template < template <int> class B0,
           template <int> class B1,
           template <int> class B2  >
struct X : public B0<1>,
                  B1<B0<1>::size * B0<1>::offset >,
                  B2< B1<B0<1>::size * B0<1>::offset >::size *
                      B1<B0<1>::size * B0<1>::offset >::offset >
{ };
int main(int argc, const char *argv[])
{
    X<A, B, C> x;
    return 0;
}

可能:

template <int Var, template <int> Head, typename... Tail>
struct X_helper : Head<Var>,
                , X_helper<Head<Var>::size * Head<Var>::offset, Tail...>
{};
template <int Var, template <int> Arg>
struct X_helper : Head<Var>
{};
template <typename... Args>
struct X : X_helper<1, Args...>
{};

我希望我的语义是正确的。

你仍然对这个问题感兴趣吗?

我正在使用C++11,所以我试着回答。

我不确定你想要什么(嗯……你在2012年想要什么),但我认为下面的例子应该符合你的要求。

template<int OFFSET>
struct A { enum O { offset = OFFSET }; enum S { size = 2 }; };
template<int OFFSET>
struct B { enum O { offset = OFFSET }; enum S { size = 4 }; };
template<int OFFSET>
struct C { enum O { offset = OFFSET }; enum S { size = 10 }; };
template <int N, template <int> class ...>
   struct H;
template <int N>
   struct H<N>
    { };
template <int N,
          template <int> class C1,
          template <int> class ... Cs>
   struct H<N, C1, Cs...> : public C1<N>,
                            public H<C1<N>::size * C1<N>::offset, Cs...>
    { };
template <template <int> class ... C>
   struct X : public H<1, C...>
    { };
int main()
 {
   X<A, B, C> x;
   return 0;
 }

p.s.:很抱歉我的英语不好