功能模板的规范

时间:2011-12-04 19:07:46

标签: c++ templates derived-class base-class function-templates

我想创建一个函数模板,其中类T仅限于特殊基类T_base的派生类。实现这一目标的有效方法是什么?谢谢你的帮助!

3 个答案:

答案 0 :(得分:7)

您可以使用类型特征和SFINAE

template<typename T, 
         bool[std::is_base_of<T_base, T>::value] = nullptr>
void f(T const&);

C ++ 03版本,也适用于C ++ 11

template<typename T>
typename boost::enable_if< boost::is_base_of<T_base, T> >::type 
f(T const&);

有使用默认参数将enable_if移动到模板参数列表的C ++ 11版本

template<typename T, 
         typename = typename std::enable_if<
           std::is_base_of<T_base, T>::value>::type>
void f(T const&);

遗憾的是,如果您的其他重载的唯一区别是SFINAE字符串(即默认参数),则您不能重载f,因为默认参数不是函数模板签名的一部分。但是模板参数的类型是自己的(这些规则就像普通的函数参数一样)。

答案 1 :(得分:1)

C ++ 0x有std::enable_if;如果你的编译器还不支持它,那就是boost::enable_if

例如,如果签名为template<typename T> int f(T&),则使用

template<typename T>
  std::enable_if<std::is_base_of<T_base, T>::value, int>::type f(T&);

答案 2 :(得分:0)

我能想到的最简单的方法就是这样:

template<class T>
void someFunc(T arg)
{
    dynamic_cast<BaseClass>(arg); // will throw an exception if not castable to base class
    // continue...
}