模板类的静态模板成员函数

时间:2015-10-17 02:56:58

标签: c++ templates c++14 template-specialization partial-specialization

我有一个模板类和一个模板成员函数:

template<class T1>
struct A{
    template<class T2>
    static int f(){return 0;}
};

我想专注于T1T2相同的情况,

例如,为任何A<T>::f<T>定义案例T

但我无法找到关键字组合来实现这一目标。

如何部分(?)专门化模板类和模板静态函数的组合?

这些是不成功的尝试,以及错误消息:

1)在课堂内专攻:fatal error: cannot specialize a function 'f' within class scope

template<class T1>
struct A{
    template<class T2>
    static int f(){return 0;}

    template<>
    static int f<T1>(){return 1;}

};

2)在课堂外专攻&#34;同时&#34;:fatal error: cannot specialize a member of an unspecialized template

template<class T>
void A<T>::f<T>(){return 1;}

3)使用template<>fatal error: too few template parameters in template redeclaration

进行专业化
template<> template<class T>
void A<T>::f<T>(){return 1;}

4)反转订单:fatal error: cannot specialize (with 'template<>') a member of an unspecialized template

template<class T> template<>
void A<T>::f<T>(){return 1;}

5)专门研究全班(基于尝试3的错误):fatal error: class template partial specialization does not specialize any template argument; to define the primary template, remove the template argument list

template<class T> 
struct A<T>{
    template<>
    static int f<T>(){return 1;}
};

6)专业化课程而不是功能(?):fatal error: too few template parameters in template redeclaration template<> template<class T1>

template<> template<class T>
int A<T>::f(){return 0;}

我使用clang 3.5 C++14生成错误消息。

1 个答案:

答案 0 :(得分:2)

你不能部分专门化一个功能。

您可以将作品转发到其他类型:

template<class T1>
struct A;

template<class T1, class T2>
struct A_helper {
  static int f() {
    return A<T1>::f_simple<T2>();
  }
};
template<class T>
struct A_helper<T,T> {
  static int f() {
    return A<T>::f_special();
  }
};

template<class T1>
struct A{
  template<class T2>
  static int f(){return A_helper<T1,T2>::f()}
  template<class T2>
  static int f_simple(){return 0;}
  static int f_special(){return -1;}
};

或更简单地说,没有A_helper

template<class T1>
struct A{
  template<class T2>
  static int f(){return f2<T2>(std::is_same<T1,T2>{});}
  template<class T2>
  static int f2(std::true_type){
    static_assert(std::is_same<T1,T2>{}, "bob!");
    return -1;
  }
  tempalte<class T2>
  static int f2(std::false_type){return -1;}
};

您可以使用标签调度。

另一种方法:

template<class T>struct tag{};

template<class T1>
struct A{
  template<class T2>
  static int f(){return f2(tag<T2>{});}
  template<class T2>
  static int f2(tag<T2>) {return 0;}
  static int f2(tag<T1>) {return -1;}
};

我们直接发送T2的类型。