Sobes.tech
Назад к вопросам
Junior — Middle
89

Каким образом осуществлялось управление нагрузкой в системе?

Компании, где спрашивали
101ХР101ХР

Ответ от нейросети

sobes.tech AI

Управление нагрузкой в системе на C/C++ обычно осуществляется несколькими способами:

  • Балансировка потоков: распределение задач между потоками для равномерного использования ресурсов CPU.
  • Использование очередей задач: задачи ставятся в очередь и обрабатываются по мере освобождения ресурсов.
  • Пул потоков: создание ограниченного количества потоков, которые переиспользуются для выполнения задач, чтобы избежать накладных расходов на создание и уничтожение потоков.
  • Мониторинг и адаптация: отслеживание текущей нагрузки и динамическое изменение параметров (например, количества потоков).

Пример простого пула потоков на C++11:

#include <iostream>
#include <thread>
#include <vector>
#include <queue>
#include <mutex>
#include <condition_variable>
#include <functional>

class ThreadPool {
    std::vector<std::thread> workers;
    std::queue<std::function<void()>> tasks;
    std::mutex queue_mutex;
    std::condition_variable condition;
    bool stop = false;

public:
    ThreadPool(size_t threads) {
        for(size_t i = 0; i < threads; ++i)
            workers.emplace_back([this] {
                for(;;) {
                    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();
                }
            });
    }

    template<class F>
    void enqueue(F&& f) {
        {
            std::unique_lock<std::mutex> lock(queue_mutex);
            tasks.emplace(std::forward<F>(f));
        }
        condition.notify_one();
    }

    ~ThreadPool() {
        {
            std::unique_lock<std::mutex> lock(queue_mutex);
            stop = true;
        }
        condition.notify_all();
        for(std::thread &worker: workers)
            worker.join();
    }
};