使用带可变参数模板的条件定义

时间:2014-03-20 08:11:18

标签: c++ templates c++11 variadic-templates enable-if

如果我有一个模板函数,它接受已知数量的模板参数,我可以使用enable_if语句和is_base_of之类的内容来限制合法类型。例如:

template <typename T>
typename enable_if<is_base_of<BaseClass, T>::value, void>::type
function() {
    // do stuff with T, which is ensured to be a child class of BaseClass
}

现在假设我们想为可变参数模板做同样的事情 - 检查以确保所有类型都是特定基类的子类。

template <typename... T>
/* What goes here? */
function() {
    // do stuff with the T types, which are ensured to be child classes of BaseClass
}

您将如何编写此条件定义?

1 个答案:

答案 0 :(得分:4)

您可以使用以下type_traits:

template <typename Base, typename T, typename... Ts>
struct are_base_of :
    std::conditional<std::is_base_of<Base, T>::value, are_base_of<Base, Ts...>,
                     std::false_type>::type
{};

template <typename Base, typename T>
struct are_base_of<Base, T> : std::is_base_of<Base, T> {};

然后使用

template <typename... Ts>
typename std::enable_if<are_base_of<BaseClass, Ts...>::value, void>::type
function() {
    // do stuff with Ts, which is ensured to be a child class of BaseClass
}