C ++可变参数模板迭代向量并比较元素

马丁·佩里

我有一个可变的班级模板

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] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章