使用acchacent_difference编译错误

Compile error using adjacent_difference

本文关键字:编译 错误 difference acchacent 使用      更新时间:2023-10-16

我正在尝试使用两种不同的迭代器类型使用Adjacent_difference。我创建的函子将输入标准器用作参数的类型,并返回输出仪使用的类型。我不明白为什么我包含的代码不编译:

在/usr/include/c /4.9/numeric:62:0中包含的文件中 从4:/usr/include/c /4.9/bits/stl_numeric.h:在'_outputiterator的实例化中 std :: adjacent_difference(_inputiterator,_inputiterator, _Outputiterator,_binaryOperation([带有_inputiterator = __gnu_cxx :: __ ___ normal_iterator>;_outputiterator = __gnu_cxx :: __ normal_iterator>;_binaryOperation = {匿名} :: checkop]': 48:85:从这里需要 /USR/include/c /4.9/bits/stl_numeric.h:374:17:错误:无法转换 '_valueType {aka test}'to tossment在分配中 *__结果= __value;

// Example program
#include <iostream>
#include <string>
#include <numeric>
#include <vector>
struct Test
{
    float first;
    float second;
};
namespace{
    class CheckOp {
    public:
        float operator()(Test x, Test y) const
        {
            float a = x.first - y.first;
            float b = x.second - y.second;
            return a + b;
        }
    };
}
int main()
{
    std::vector<Test> testVec;
    Test test1;
    test1.first = 5.5F;
    test1.second = 6.5F;
    testVec.push_back(test1);
    Test test2;
    test2.first = 2.5F;
    test2.second = 8.5F;
    testVec.push_back(test2);
    Test test3;
    test3.first = 9.4F;
    test3.second = 7.8F;
    testVec.push_back(test3);
    CheckOp checkOP;
    std::vector<float> resultVec(testVec.size());
    std::adjacent_difference(testVec.begin(), testVec.end(), resultVec.begin(), checkOP);

}

注意adjacent_difference的描述(来自cppReference(:

首先,创建一个累加器acc,其类型是InputIt的值类型,用*first初始化它,然后将结果分配给*d_first

这意味着输入和输出序列必须具有相同或至少兼容的类型。