Что такое Worker Pool? Использовали его?
Ответ от нейросети
sobes.tech AI
Worker Pool — это паттерн проектирования, который используется для управления пулом потоков (воркеров), которые выполняют задачи из общей очереди. Идея в том, чтобы ограничить количество одновременно работающих потоков и переиспользовать их для обработки множества задач, что повышает производительность и снижает накладные расходы на создание и уничтожение потоков.
В C++ это часто реализуется через класс, который содержит очередь задач и фиксированное количество потоков, которые постоянно берут задачи из очереди и выполняют их.
Пример упрощённой реализации Worker Pool на C++ с использованием std::thread и std::queue:
#include <iostream>
#include <thread>
#include <queue>
#include <mutex>
#include <condition_variable>
#include <functional>
#include <vector>
#include <atomic>
class WorkerPool {
std::vector<std::thread> workers;
std::queue<std::function<void()>> tasks;
std::mutex queue_mutex;
std::condition_variable condition;
std::atomic<bool> stop;
public:
WorkerPool(size_t threads) : stop(false) {
for (size_t i = 0; i < threads; ++i) {
workers.emplace_back([this] {
while (true) {
std::function<void()> task;
{
std::unique_lock<std::mutex> lock(this->queue_mutex);
this->condition.wait(lock, [this]{ return this->stop || !this->tasks.empty(); });
if (this->stop && this->tasks.empty())
return;
task = std::move(this->tasks.front());
this->tasks.pop();
}
task();
}
});
}
}
void enqueue(std::function<void()> task) {
{
std::unique_lock<std::mutex> lock(queue_mutex);
tasks.push(std::move(task));
}
condition.notify_one();
}
~WorkerPool() {
stop = true;
condition.notify_all();
for (std::thread &worker : workers) {
if(worker.joinable())
worker.join();
}
}
};
int main() {
WorkerPool pool(4);
pool.enqueue([]{ std::cout << "Task 1" << std::endl; });
pool.enqueue([]{ std::cout << "Task 2" << std::endl; });
std::this_thread::sleep_for(std::chrono::seconds(1));
}
Да, использовал в проектах для организации параллельной обработки задач с контролем количества потоков.