我有一个可变的班级模板
template <size_t ...T>
struct Foo
{
std::vector<size_t> t;
bool IsEqual()
{
//??
}
};
我想像这样使用:
Foo<1,2,3,4> foo;
foo.data = {1,2,3,4};
foo.IsEqual();
IsEqual
如果元素与模板参数的顺序相同,如何实现迭代和比较向量的每个元素并返回false / true的方法?
使用索引序列技巧:
bool IsEqual()
{
return t.size() == sizeof...(T) &&
IsEqual(std::make_index_sequence<sizeof...(T)>{});
}
与:
template <size_t... Is>
bool IsEqual(std::index_sequence<Is...> ) {
bool valid = true;
using expander = int[];
expander{0,
(valid = valid && t[Is] == T,
0)...
};
return valid;
}
利用以下事实,甚至可以在一个函数中做到这一点:在一个初始化函数子句中,每个值的计算和副作用都在下一个函数之前进行一次排序:
bool IsEqual()
{
if (t.size() == sizeof...(T)) {
auto it = t.begin();
bool valid = true;
using expander = int[];
expander{0,
(valid = valid && *it++ == T,
0)...
};
return valid;
}
else {
return false;
}
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句