Соответствующие вопросы:
О С++ 11:
- С++ 11: std:: thread пул?
- Будет ли async (запуск:: async) в С++ 11 сделать пулы потоков устаревшими, чтобы избежать дорогостоящего создания потоков?
О Boost:
Как мне получить пул потоков для отправки задач на, не создавая и не удаляя их снова и снова? Это означает, что постоянные потоки для повторной синхронизации без соединения.
У меня есть код, который выглядит так:
namespace {
std::vector<std::thread> workers;
int total = 4;
int arr[4] = {0};
void each_thread_does(int i) {
arr[i] += 2;
}
}
int main(int argc, char *argv[]) {
for (int i = 0; i < 8; ++i) { // for 8 iterations,
for (int j = 0; j < 4; ++j) {
workers.push_back(std::thread(each_thread_does, j));
}
for (std::thread &t: workers) {
if (t.joinable()) {
t.join();
}
}
arr[4] = std::min_element(arr, arr+4);
}
return 0;
}
Вместо того, чтобы создавать и присоединять потоки к каждой итерации, я бы предпочел отправлять задачи на мои рабочие потоки на каждую итерацию и создавать их только один раз.