22

我试图了解不同的用例。以及2个线程使用之间的区别。 是我读过的一个很好的教程,它解释了boost::thread_group

这是我正在使用的代码:

boost::threadpool::pool s_ThreadPool(GetCoreCount());

CFilterTask task(pFilter,  // filter to run
    boost::bind(&CFilterManagerThread::OnCompleteTask, this, _1, _2) // OnComplete sync callback          // _1 will be filter name  // _2 will be error code
                );

// schedule the new task - runs on the threadpool
s_ThreadPool.schedule(task);

这是析构函数:

s_ThreadPool.wait(0);

你能解释一下吗?

4

1 回答 1

47

boost::thread_group是用于在线程集合上执行线程管理操作的便利类。例如,不必迭代,在每个线程上std::vector<boost::thread>调用,提供了一个方便的成员函数。join()thread_groupjoin_all()

使用boost::thread,不管它是由 管理的boost::thread_group,线程的生命周期通常取决于线程正在执行的工作。例如,如果创建一个线程来执行计算量很大的计算,那么一旦计算出结果,该线程就可以退出。如果工作是短暂的,那么创建和销毁线程的开销会影响性能。

另一方面,线程是一种模式,其中许多线程服务于许多任务/工作。线程的生命周期与任务的生命周期没有直接关联。继续前面的示例,应用程序将安排计算量大的计算在线程池中运行。工作将在线程池中排队,并选择线程池的线程之一来执行工作。计算完成后,线程返回等待线程池安排更多工作。

如这个线程池示例所示可以实现线程池boost::thread_group来管理线程的生命周期,以及boost::asio::io_service用于任务/工作分派。

于 2013-05-21T20:36:51.007 回答