【C++】 条件变量实现线程同步示例

在做一些比较大的项目的时候,需要实现线程同步, 这里结合一个小示例,进行线程同步的讲解

问题定义

以下是一个使用 C++ 多线程和条件变量的示例,展示了线程 A 接收一个 enable 信号并通知线程 B 开始工作。线程 B 在开始工作之前将 enable 信号设置为 false,然后执行其任务。

#include <iostream>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <atomic>

// 共享数据
std::atomic<bool> enable(false);
std::mutex mtx;
std::condition_variable cv;

void threadA() {
    // 模拟接收 enable 信号
    std::this_thread::sleep_for(std::chrono::seconds(1));
    {
        std::lock_guard<std::mutex> lock(mtx);
        enable = true;
    }
    std::cout << "Thread A: enable signal received. Notifying thread B." << std::endl;
    cv.notify_one(); // 通知线程 B
}

void threadB() {
    std::unique_lock<std::mutex> lock(mtx);
    // 等待 enable 信号
    cv.wait(lock, [] { return enable.load(); });
    std::cout << "Thread B: Received notification. Setting enable to false." << std::endl;
    enable = false; // 将 enable 信号设置为 false

    // 进行工作
    std::cout << "Thread B: Working..." << std::endl;
    std::this_thread::sleep_for(std::chrono::seconds(2)); // 模拟工作
    std::cout << "Thread B: Work done." << std::endl;
}

int main() {
    std::thread tA(threadA);
    std::thread tB(threadB);

    tA.join();
    tB.join();

    return 0;
}

代码说明

  1. 共享数据
    • enable:使用 std::atomic<bool> 进行原子操作,确保线程安全。
    • mtx:互斥锁,用于保护共享数据。
    • cv:条件变量,用于线程之间的同步。
  2. **threadA**** 函数**:
    • 模拟接收 enable 信号。
    • 设置 enabletrue,表示信号已接收。
    • 通知线程 B。
  3. **threadB**** 函数**:
    • 等待 enable 信号。条件变量 cv.wait 保证线程在 enabletrue 之前不会继续执行。
    • 在接收到通知后,将 enable 设置为 false
    • 执行其任务。
  4. **main**** 函数**:
    • 创建并启动线程 A 和线程 B。
    • 等待线程 A 和线程 B 完成。

这个示例展示了如何使用条件变量和原子变量进行线程间的同步和数据共享。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用条件变量实现线程同步的步骤如下: 1. 创建条件变量和互斥锁:首先,需要创建一个条件变量和一个互斥锁。条件变量用于线程之间的通信,互斥锁用于保护共享资源。 2. 加锁:在访问共享资源之前,需要先获取互斥锁,确保只有一个线程可以访问共享资源。 3. 检查条件:在访问共享资源之前,需要检查条件是否满足。如果条件不满足,则线程需要等待。 4. 等待条件:如果条件不满足,线程需要等待条件变量的通知。调用条件变量的等待函数,将线程置于等待状态,并释放互斥锁,允许其他线程访问共享资源。 5. 接收通知:当其他线程改变了共享资源,并满足了条件时,需要发送通知给等待的线程。调用条件变量的通知函数,唤醒一个或多个等待的线程。 6. 解锁:当接收到通知后,等待的线程被唤醒,需要重新获取互斥锁,并继续执行。 下面是一个使用条件变量实现线程同步示例代码: ```c++ #include <iostream> #include <thread> #include <condition_variable> std::mutex mtx; std::condition_variable cv; bool ready = false; void worker_thread() { // 加锁 std::unique_lock<std::mutex> lock(mtx); // 检查条件 while (!ready) { // 等待条件 cv.wait(lock); } // 条件满足,执行任务 std::cout << "Worker thread is working." << std::endl; } int main() { // 创建工作线程 std::thread worker(worker_thread); // 做一些其他的工作... // 准备好条件 { std::lock_guard<std::mutex> lock(mtx); ready = true; } // 发送通知 cv.notify_one(); // 等待工作线程完成 worker.join(); return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值