3

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

4

3 回答 3

7

您可以使用类型特征和 SFINAE

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

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

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

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

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

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

于 2011-12-04T19:14:10.113 回答
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&);
于 2011-12-04T19:25:59.527 回答
0

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

template<class T>
void someFunc(T arg)
{
    dynamic_cast<BaseClass>(arg); // will throw an exception if not castable to base class
    // continue...
}
于 2011-12-04T19:16:16.177 回答