Sobes.tech
Back to questions
Junior — Middle
89

Какими способами осуществляется обмен данными между потоками выполнения?

Answer from AI

sobes.tech AI

Обмен данными между потоками выполнения в C/C++ может осуществляться несколькими способами:

  1. Общие переменные и память — потоки могут читать и записывать данные в общую область памяти. Для предотвращения гонок данных используются механизмы синхронизации (мьютексы, семафоры).

  2. Мьютексы и блокировки — для защиты критических секций и обеспечения согласованности данных.

  3. Условные переменные (condition variables) — позволяют потокам ожидать определённого состояния или события.

  4. Очереди сообщений (message queues) — потоки могут обмениваться сообщениями через потокобезопасные очереди.

  5. Атомарные операции — для простых операций без блокировок, используя std::atomic.

Пример использования мьютекса для защиты общей переменной:

#include <iostream>
#include <thread>
#include <mutex>

int counter = 0;
std::mutex mtx;

void increment() {
    for (int i = 0; i < 1000; ++i) {
        std::lock_guard<std::mutex> lock(mtx);
        ++counter;
    }
}

int main() {
    std::thread t1(increment);
    std::thread t2(increment);
    t1.join();
    t2.join();
    std::cout << "Counter: " << counter << std::endl;
    return 0;
}

Таким образом, выбор способа обмена данными зависит от задачи и требований к синхронизации и производительности.