#include
using namespace std;
template
class A {
public:
void taunt() { cout << \"A\"; }
};
template
You can use a (sensible) default for the second instantiating type:
template <class T1, typename T2 = void>
class A {
public:
void taunt() { cout << "A"; }
};
Template specialization can't be used to reduce the number of template arguments, to do that you should use defaults for some of the arguments.
So in order to allow usage of only one argument, and make that usage hit your specialization, you need a default for the second argument, which is the same as the first argument:
#include <iostream>
using namespace std;
template <class T1, class T2=T1>
class A {
public:
void taunt() { cout << "A"; }
};
template <class T1>
class A<T1, T1> {
public:
void taunt() { cout << "B"; }
};
class B {};
class C {};
int main (int argc, char * const argv[]) {
A<B> a;
a.taunt(); // Prints "B"
return 0;
}