c++中mutex互斥锁怎么使用_C++ std::mutex互斥锁同步教程

std::mutex用于保护共享数据,防止数据竞争。需包含头文件并定义互斥量,通过lock()/unlock()手动加解锁,但推荐使用std::lock_guard实现RAII自动管理,确保异常安全;在类中可为成员函数加锁保护共享成员变量,合理控制锁粒度以平衡性能与安全性。

c++中mutex互斥锁怎么使用_c++ std::mutex互斥锁同步教程

在C++多线程编程中,std::mutex 是用于保护共享数据、防止多个线程同时访问的关键工具。如果不加控制地让多个线程同时修改同一块数据,会导致数据竞争(data race),从而引发未定义行为。使用互斥锁可以确保同一时间只有一个线程能进入临界区。

1. 包含头文件并声明互斥量

要使用 std::mutex,需要包含 头文件。然后可以在全局、类成员或局部作用域中定义一个互斥量。

#include iostream>
#include
#include

示例:

std::mutex mtx; // 全局互斥量
int shared_data = 0;

2. 使用 lock() 和 unlock() 手动加锁解锁

最基础的用法是在线程函数中调用 lock() 进入临界区,操作完成后调用 unlock() 释放锁。

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

void unsafe_increment() {
    mtx.lock();
    shared_data++;
    std::cout             mtx.unlock();
}

创建多个线程调用该函数:

int main() {
    std::thread t1(unsafe_increment);
    std::thread t2(unsafe_increment);
    t1.join();
    t2.join();
    return 0;
}

这样可以避免两个线程同时修改 shared_data 导致的数据错乱。

3. 推荐方式:使用 std::lock_guard 自动管理锁

手动调用 lock()unlock() 容易出错,比如忘记解锁或异常导致提前退出。C++ 提供了 RAII 风格的 std::lock_guard,它在构造时自动加锁,析构时自动解锁。

改写上面的例子:

void safe_increment() {
    std::lock_guard guard(mtx); // 自动加锁
    shared_data++;
    std::cout         } // guard 离开作用域,自动解锁

这种方式更安全,即使函数中抛出异常,也能保证锁被正确释放。

4. 在类中使用互斥量保护成员数据

当多个线程访问同一个对象的成员变量时,也需要加锁保护。

class Counter {
private:
    int value;
    std::mutex mtx;
public:
    Counter() : value(0) {}

    void increment() {
        std::lock_guard guard(mtx);
        value++;
    }

    int get() const {
        std::lock_guard guard(mtx);
        return value;
    }
};

每个成员函数都通过 lock_guard 保护对 value 的访问,确保线程安全。

基本上就这些。合理使用 std::mutexstd::lock_guard 能有效避免数据竞争,提升程序稳定性。注意不要过度加锁影响性能,也不要把锁粒度放得太粗或太细。关键是识别哪些资源是共享且可变的,然后加以保护。

以上就是c++++中mutex互斥锁怎么使用_C++ std::mutex互斥锁同步教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1479598.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 03:55:48
下一篇 2025年12月19日 03:55:54

相关推荐

发表回复

登录后才能评论
关注微信