在this question中,我未能成功地询问如何根据模板参数使用不同的pimpl实现。
也许这个例子更能说明我想做的事情:
#include <iostream>
template< int N, typename T >
struct B
{
B() : c( new C< N > )
{}
template< int M >
struct C;
C< N > *c;
};
template< int N, typename T >
template< int M >
struct B< N, T >::C
{
int a[M];
};
// version 1 that doesn't work
template< int N, typename T >
template< >
struct B< N, T >::C< 0 >
{
int a;
};
// version 2 that doesn't work
template< typename T >
template< int M >
struct B< 0, T >::C
{
int a;
};
int main()
{
B< 0, float > b0;
B< 1, int > b1;
std::cout << "b0 = " << sizeof(b0.c->a) << std::endl;
std::cout << "b1 = " << sizeof(b1.c->a) << std::endl;
}
如果我尝试专门化struct C(上面没有编译)
,它仍然会失败那么,有可能吗?
我知道这样的解决方法:
template< int M >
struct D
{
int a[M];
};
template< >
struct D<0>
{
int a;
};
template< int N, typename T >
template< int M >
struct B< N, T >::C
{
D< M > helper;
};
但如果可能的话,我想避免它
答案 0 :(得分:3)
语言不允许您尝试做的事情。
§14.7.3.16(FCD 2010-03-26)声明:
明确的专业化 一个班级成员的声明 模板或成员模板 出现在命名空间作用域中的成员 模板和它的一些封闭 类模板可能会保留 非专业,除了 声明不得明确 如果要专门化一个类成员模板 它的封闭类模板不是 也明确专业化。在 这种明确的专业化 声明,关键字模板 后跟一个template-parameter-list 应提供而不是 模板&LT;&GT;在显式之前 专业化宣言 会员。的类型 模板参数 template-parameter-list应该是 与主要指定的相同 模板定义。
[ Example:
template <class T1> class A {
template<class T2> class B {
template<class T3> void mf1(T3);
void mf2();
};
};
template <> template <class X>
class A<int>::B {
template <class T> void mf1(T);
};
template <> template <> template<class T>
void A<int>::B<double>::mf1(T t) { }
template <class Y> template <>
void A<Y>::B<double>::mf2() { } // ill-formed; B<double> is specialized but
// its enclosing class template A is not
—end example ]