#include <iostream>
template <typename T1, typename T2>
class B{
public:
void update(){ std::cerr<<__PRETTY_FUNCTION__<<std::endl; }
void func1(){ std::cerr<<__PRETTY_FUNCTION__<<std::endl; }
void func2(){ std::cerr<<__PRETTY_FUNCTION__<<std::endl; }
};
template <typename T1>
class B<T1, int>{
public:
void update(){ std::cerr<<__PRETTY_FUNCTION__<<"(specialization)"<<std::endl;}
};
int main(){
B<int, double> b1;
b1.update();
b1.func1();
B<int, int> b2;
b2.update();
//b2.func1();//there's no function 'func1' in B<int,int>
}
Я хочу специализировать функцию update
для определенного параметра шаблона (типа данных).
Итак, я попытался специализировать template class B
, но, похоже, мне нужно снова реализовать целые функции-члены.
Поскольку другие члены в разных специализациях абсолютно одинаковы, повторная реализация целых членов выглядит громоздкой.
Есть ли обходной путь для этого случая?