for_each中的C ++ functor意外行为

时间:2015-08-21 01:35:30

标签: c++ stl functor

考虑以下示例:

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

class accum
{
public:
    int sum;
    accum()
    {
        sum = 0;
    }
    void operator() (int a)
    {
        sum += a;
        printf("sum=%d\n",sum);
    }
};

int main()
{
     int ari[] = {2,8,5,9,1};
     vector<int> vi(&ari[0], &ari[5]);
     accum f;
     for_each(vi.begin(), vi.end(), f);
     printf("final sum : %d\n", f.sum);
}

我预计总和为25,但会打印0。为什么f保持不变?有人能详细介绍一下发生了什么吗?

1 个答案:

答案 0 :(得分:5)

那是因为std::for_each通过 value 来获取其仿函数,而不是通过引用。它在f的副本内部运行,并且您传入的副本保持不变。它会将返回函子返回给你,所以你可以覆盖你的:

accum f = std::for_each(vi.begin(), vi.end(), accum());

或者,坚持使用C ++ 03,让accum参考:

struct accum {
    int& sum;
    // rest as before, fixing the constructor
};

int sum = 0;
std::for_each(vi.begin(), vi.end(), accum(sum));
printf("final sum : %d\n", sum);

虽然您可能只想要std::accumulate

int sum = std::accumulate(vi.begin(), vi.end(), 0);

或者,在C ++ 11中,for_each带有lambda:

int sum = 0;
std::for_each(vi.begin(), vi.end(), [&](int a){ sum += a; });