C++中的并发与锁怎么用?C++ mutex互斥锁使用教程【多线程安全】

admin 百科 10
多线程中需用std::mutex等同步机制保证共享数据访问安全,核心是所有读写均须在持锁下进行;推荐RAII方式如std::lock_guard或std::unique_lock管理锁,避免手动lock/unlock出错;注意mutable修饰互斥量以支持const函数加锁,多锁场景优先用std::scoped_lock防死锁。

C++中的并发与锁怎么用?C++ mutex互斥锁使用教程【多线程安全】-第1张图片-佛山资讯网

多线程环境下,多个线程同时访问共享数据容易引发数据竞争(data race),导致结果不可预测。C++ 提供 std::mutex 等同步机制来保证线程安全,核心原则是:**任何对共享资源的读写,都必须在持有互斥锁的前提下进行**。

mutex 基本用法:加锁、解锁、RAII 自动管理

手动调用 lock()unlock() 容易出错(比如忘记解锁、异常跳过解锁)。推荐使用 RAII 封装类:std::lock_guard(作用域内自动加锁/解锁)或更灵活的 std::unique_lock

  • std::lock_guard<:mutex> guard(mtx);</:mutex> —— 构造时加锁,离开作用域自动解锁(不能转移、不可复制)
  • std::unique_lock<:mutex> lock(mtx);</:mutex> —— 支持延迟加锁、手动解锁、条件变量配合等
  • 不要手动调用 mtx.unlock() 配合 lock_guard,否则会触发未定义行为

保护共享变量:典型线程安全计数器示例

下面是一个带锁的线程安全计数器:

class ThreadSafeCounter {
    mutable std::mutex mtx;
    int value = 0;
public:
    void increment() {
        std::lock_guard<std::mutex> lock(mtx);
        ++value;
    }
    int get() const {
        std::lock_guard<std::mutex> lock(mtx);
        return value;
    }
};

登录后复制

注意:mutable 允许在 const 成员函数中修改互斥量(因为锁操作不改变逻辑状态);get()const 函数,但内部仍需加锁读取共享值。

立即学习“C++免费学习笔记(深入)”;

标签: ai c++ 一加 数据访问 作用域 同步机制 有锁

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~