【发布时间】:2014-07-01 18:22:27
【问题描述】:
我是 C++11 中的线程新手,我想知道如何管理工作线程(使用标准库)以执行某些任务然后消失。我有一个线程池vector<thread *> thread_pool,它维护着一个活动线程列表。
假设我启动一个新线程并使用thread_pool.push_back(new thread(worker_task)) 将其添加到池中,其中worker_task 定义如下:
void worker_task()
{
this_thread::sleep_for(chrono::milliseconds(1000));
cout << "Hello, world!\n"
}
一旦工作线程终止,从池中可靠地移除线程的最佳方法是什么?主线程需要连续运行并且不能阻塞join 调用。我对代码的一般结构比对同步的复杂性更感到困惑。
编辑: 看起来我在代码中误用了池的概念。我的意思是我有一个当前正在运行的线程列表。
【问题讨论】:
-
如果每个线程只执行一个任务,线程池的目的是什么?
-
kernel.org/pub/linux/kernel/people/paulmck/perfbook/… 在考虑构建线程池架构之前阅读此内容。
-
“池”不是这个意思……
-
@nosid 为了这个问题,我简化了情况。我正在创建的线程不会像上面显示的 worker_task 函数那么短,并且我需要能够显示所有线程在任何给定时间正在处理的内容。 thread_pool 实际上不会包含线程对象列表,但会包含与每个线程关联的元数据。
标签: multithreading c++11