考虑以下示例:
#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
保持不变?有人能详细介绍一下发生了什么吗?
答案 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; });