我想创建一个函数模板,其中类T仅限于特殊基类T_base的派生类。实现这一目标的有效方法是什么?谢谢你的帮助!
答案 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...
}