我可以编写一个递归Contains
元函数,要么通过继承调用自身,要么通过嵌套的 typedef。以下标准有什么区别(如果有的话)?
A:编译时需要的编译时间和内存。
B:最大递归限制(一个允许我使用比另一个更多的参数吗?)
C:惰性实例化(允许我省略更多实例化吗?这在当前示例中可能没有什么不同。但是,如果一个类有嵌套的类型定义std::conditional
vs 是从它派生的?)
1:
template<typename T, typename... Ts>
struct Contains : std::false_type {}; //only possible if Ts is empty so does not contain
template<typename T, typename U, typename... Ts>
struct Contains<T, U, Ts...> : Contains<T, Ts...>{};
template<typename T, typename... Ts>
struct Contains<T, T, Ts...> : std::true_type{};
2:
template<typename T, typename... Ts>
struct Contains {
typedef std::false_type Type;
}; //only possible if Ts is empty so does not contain
template<typename T, typename U, typename... Ts>
struct Contains<T, U, Ts...> {
typedef typename Contains<T, Ts...>::Type Type;
};
template<typename T, typename... Ts>
struct Contains<T, T, Ts...>{
typedef std::true_type Type;
};