当我在没有-std=gnu++11开关的情况下编译时,这个循环工作得很好。如果使用-std=gnu++11进行编译,则会得到以下错误:
no match for call to '(__gnu_cxx::__normal_iterator<const float*, std::vector<float> >) (const float&, const float&)' if (!bool(__binary_pred(*__first1, *__first2))) 我的代码:
for (auto it_A = std::begin(vector_A); it_A != std::end(vector_A); it_A += 4)
{
bool found_in_B = false;
for (auto it_B = std::begin(vector_B); !found_in_B && it_B != std::end(vector_B); it_B += 4)
{
found_in_B = std::equal(it_A, it_A + blockSize, it_B, it_B + blockSize);
}
}发布于 2018-05-03 11:30:23
直到C++14,std::equal需要三个迭代器:两个描述第一个范围,一个描述第二个范围的开始。没有理由采取第四个迭代器,因为这两个范围必须是相同的长度(同样,直到C++14)。
四迭代器版本是在C++14中添加的,您所选择的语言变体是不可用的(该标志影响标准库,而不仅仅是语言)。
由于代码中的范围长度总是匹配的,所以只需删除第四个参数即可。
https://stackoverflow.com/questions/50153752
复制相似问题