在Java中,我会做类似的事情:
Thread t = new MyThread();
t.start();
我通过调用start()方法启动线程。所以后来我可以做类似的事情:
for (int i = 0; i < limit; ++i)
{
Thread t = new MyThread();
t.start();
}
创建一组线程并在run()方法中执行代码。
但是,在C ++中,没有start()方法。使用Boost,如果我想要一个线程开始运行,我必须调用join()方法才能使线程运行。
#include <iostream>
#include <boost/thread.hpp>
class Worker
{
public:
Worker()
{
// the thread is not-a-thread until we call start()
}
void start(int N)
{
m_Thread = boost::thread(&Worker::processQueue, this, N);
}
void join()
{
m_Thread.join();
}
void processQueue(unsigned N)
{
float ms = N * 1e3;
boost::posix_time::milliseconds workTime(ms);
std::cout << "Worker: started, will work for "
<< ms << "ms"
<< std::endl;
// We're busy, honest!
boost::this_thread::sleep(workTime);
std::cout << "Worker: completed" << std::endl;
}
private:
boost::thread m_Thread;
};
int main(int argc, char* argv[])
{
std::cout << "main: startup" << std::endl;
Worker worker, w2, w3, w5;
worker.start(3);
w2.start(3);
w3.start(3);
w5.start(3);
worker.join();
w2.join();
w3.join();
w5.join();
for (int i = 0; i < 100; ++i)
{
Worker w;
w.start(3);
w.join();
}
//std::cout << "main: waiting for thread" << std::endl;
std::cout << "main: done" << std::endl;
return 0;
}
在上面的代码中,for循环创建了100个线程,通常我必须使用boost :: thread_group来添加线程函数,最后用join_all()运行all。但是,我不知道如何使用线程函数放入使用各种类成员的类。
另一方面,上面的循环不会像Java中的循环那样。它将使每个线程按顺序执行,而不是像调用其自己的join()的其他分离线程一样执行。
Boost中的join()究竟是什么?另外请帮我创建一组共享同一类的线程。
答案 0 :(得分:13)
join
无法启动该线程,它会阻止您,直到您加入的线程结束。当你需要等待你开始完成其运行的线程时使用它(例如 - 如果它计算某些东西而你需要结果)。
启动线程的是boost::thread
,它创建线程并调用传递给它的线程函数(在您的情况下为Worker::processQueue
)。
你遇到循环问题的原因不是因为线程没有启动,而是因为你的主线程在完成之前没有等待它们执行。 我猜你在Java中没有看到这个问题,因为调度差异,即“未定义的行为”。 编辑后 在Java中,线程的行为略有不同,请参阅下面的注释以获取详细信息。这就解释了为什么你没有在Java中看到它。
Here's a question about the boost::thread_group
。阅读问题和答案中的代码,它将对您有所帮助。
答案 1 :(得分:6)
加入一个线程在Boost中执行与在Java中相同的操作:它等待线程完成运行。
另外,如果我没记错的话,Boost的线程会在构建时运行。你没有明确地启动它们。