专门处理默认模板参数包
Specialize on default template parameter pack
假设我已经为STL元组(元组、对)以及STL序列(向量、列表、deque)编写了通用映射函数。现在,我想编写一个全局映射函数,在给定输入类型的情况下调用适当的特殊函数。
我有一些类似的东西
template <typename... Ts>
struct mappable {
static constexpr bool is_instance = false;
};
template <typename... Tuples, typename = require<all<is_stl_tuple, Tuples...>::value>>
struct mappable<Tuples...> {
template <typename Func>
auto map(Func&& f, Tuples&&... ts) {
return tuple::map(std::forward<Func>(f), ts...);
}
static constexpr bool is_instance = true;
};
template <typename... Sequences, typename = require<all<is_stl_sequence, Sequences...>::value>>
struct mappable<Sequences...> {
template <typename Func>
auto map(Func&& f, Sequences&&... seqs) {
return sequence::map(std::forward<Func>(f), seqs...);
}
static constexpr bool is_instance = true;
};
template <typename Func, typename... Ts>
auto map(Func&& f, Ts&&... ts) {
static_assert(mappable<Ts...>::is_instance, "Tried calling map on unsupported types. Mappable arguments must be supplied.");
return mappable<Ts...>::map(std::forward<Func>(f), std::forward<Ts>(ts)...);
}
尽管希望能够自我解释的类型检查功能defs:
// true iff Unary<Ts>::value... == true for at least one Ts
template <template <typename> class Unary, typename... Ts>
struct any;
// true iff Unary<Ts>::value... == true for all Ts
template <template <typename> class Unary, typename... Ts>
struct all;
template <bool B>
using require = typename std::enable_if<B>::type;
显然,这不会(也不会)起作用,因为我专门在默认参数上进行映射。有什么方法可以做到这一点吗?如果没有(我必须重新设计),你会如何重新设计这些功能?sequence::map应该以stl序列的任何组合为例,所以我对重组的所有想法都只是把问题转移到其他地方。。。
提前感谢您的帮助。。。
编辑:根据要求,这里有一些用法示例(实际上是我的测试代码)在我开始做上述操作之前:
auto t0 = std::make_tuple(2.f, -5, 1);
auto t1 = std::make_tuple(1, 2);
auto b0 = tuple::map([] (auto v) { return v > decltype(v)(0); }, t0);
auto r0 = tuple::map([] (auto v0, auto v1) { return v0 + v1; }, t0, t1);
// b0 is tuple<bool, bool, bool>(true, false, true)
// b1 is tuple<float, int>(3.f, -3)
对于序列:
std::vector<float> s0 = {1.f, 2.f, 3.f, 0.f};
std::list<int> s1 = {3, 0, -2};
auto r = sq::map([] (auto v0, auto v1) { return v0 + v1; }, s0, s1);
// type of r is compound type of first argument (vector here), result is
// vector<float>(4.f, 2.f, 1.f)
这些映射函数的实现是完全不同的——我上面的方法的目的是能够去掉名称空间,只使用映射,让它做正确的事情。
为什么不只是两个函数重载?
template <typename Func, typename... Tuples,
require<all<is_stl_tuple, Tuples...>>...>
auto map(Func&& f, Tuples&&... ts) {
return tuple::map(std::forward<Func>(f), std::forward<Tuples>(ts)...);
}
template <typename Func, typename... Sequences,
require<all<is_stl_sequence, Sequences...>>...>
auto map(Func&& f, Sequences&&... seqs) {
return sequence::map(std::forward<Func>(f), std::forward<Sequences>(seqs)...);
}
它利用了对require
的调整,使两个过载发挥得很好:
template <bool condition>
struct require_impl {};
template <>
struct require_impl<true> {
enum class type {};
};
template <typename Condition>
using require = typename require_impl<Condition::value>::type;
相关文章:
- 使函数参数默认为周围范围
- 如何将值传递给其参数(默认参数)
- 当“std::make_index_sequence”和“std::index_sequence”用于模板参数默认类型时
- C ,构造器中允许的参考参数默认值
- 哪些规则控制参数默认赋值?
- 错误:上一个规范后给出的参数默认参数
- 是否可以设计一个包含模板参数默认值的类
- 构造函数中参数C++默认值
- 如何设置依赖于其他参数的参数默认值
- C++模板参数默认函数实现
- QInput对话框参数默认值
- g++4.8.2上列表方法参数默认初始化时出错
- 在函数定义中指定参数默认值会导致错误 C2143:语法错误:'='之前缺少')'
- 函数模板:将第一个模板参数默认为第二个
- 模板模板参数默认可以引用其他模板类型的参数
- 参数默认为先例参数的值
- 如何修改一个类,使它只有一个成员函数,所有参数默认
- 内置类型的模板参数默认值
- 是否可以使用构造函数或对象作为其他类方法的参数默认值?
- 模板参数默认为更高版本