boost :: thread - 简单示例不起作用(C ++)

时间:2013-05-16 14:10:03

标签: c++ boost-thread

要开始使用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

...然后它不起作用。

对不起,如果这很明显,但我很难过。有线索吗?

2 个答案:

答案 0 :(得分:13)

你应该使用

boost::thread thread(boost::ref(S), boost::cref(numbers));

因为默认情况下线程会复制这些参数。

答案 1 :(得分:5)

您的SumWorker对象S正在被线程构造函数复制,因此其成员永远不会更新。

http://www.boost.org/doc/libs/1_53_0/doc/html/thread/thread_management.html#thread.thread_management.thread.callable_constructor