No veo por qué la instrucción en main es ambigua.Ambigüedad de especialización de plantilla parcial
template<class T, class U, int I> struct X
{ void f() { cout << "Primary template" << endl; } };
template<class T, int I> struct X<T, T*, I>
{void f() { cout << "Partial specialization 1" << endl;}};
template<class T, class U, int I> struct X<T*, U, I>
{void f() { cout << "Partial specialization 2" << endl;}};
template<class T> struct X<int, T*, 10>
{void f() { cout << "Partial specialization 3" << endl;}};
template<class T, class U, int I> struct X<T, U*, I>
{void f() { cout << "Partial specialization 4" << endl;}};
int main()
{
X<int, int*, 10> f;
}
¿No es X<int, T*, 10>
la plantilla más especializada? Este es un ejemplo de http://publib.boulder.ibm.com/infocenter/lnxpcomp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8l.doc%2Flanguage%2Fref%2Fpartial_specialization.htm
La razón se da debajo del ejemplo: El compilador no permitió la declaración 'X' f porque puede coincidir con la plantilla struct 'X ', template struct 'X ', o template struct 'X ', y ninguna de estas declaraciones es una mejor coincidencia que las demás. –