要开始使用boost::thread
,我写了一个非常简单的例子 - 它不起作用。有谁可以指出我的错误?
我写了一个非常简单的仿函数类来完成这项工作。它应该计算std::vector
双精度的总和,并给我一种方法来获得结果:
class SumWorker
{
private:
double _sum;
public:
SumWorker() : _sum(-1.0) {}
void operator() (std::vector<double> const & arr)
{
_sum = 0.0;
for(std::vector<double>::const_iterator i = arr.begin();
i != arr.end();
i++)
{
_sum += (*i);
}
}
double const value() const
{
return _sum;
}
};
现在,我可以通过两种方式之一计算总和。如果我在主线程中这样做,比如,
SumWorker S;
S(numbers); // "numbers" is an std::vector<double>
double sum = S.value(); // "sum" now contains the sum
然后一切正常。但是,如果我尝试在一个单独的线程中执行此操作(这是重点),
SumWorker S;
boost::thread thread(S, numbers); // Should be equivalent to "S(numbers);"
thread.join(); // Wait for thread to finish
double sum = S.value(); // "sum" now contains -1.0
...然后它不起作用。
对不起,如果这很明显,但我很难过。有线索吗?
答案 0 :(得分:13)
你应该使用
boost::thread thread(boost::ref(S), boost::cref(numbers));
因为默认情况下线程会复制这些参数。
答案 1 :(得分:5)
您的SumWorker对象S正在被线程构造函数复制,因此其成员永远不会更新。