В этом вопросе я безуспешно спрашивал, как использовать различную реализацию 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;
}
Это все еще не удается, если я пытаюсь специализировать структуру 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;
};
но если возможно, я хотел бы избежать этого
B<N,T>::C<M>
N
и/илиT
вообще? Если нет, то почему он должен быть членом шаблона классаB
? - person aschepler   schedule 24.03.2011