c++ 多线程锁 mutex locker

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++线程编程中,锁是一种机制,用于控制对共享资源的访问。当多个线程同时读写同一个共享资源时,就会发生竞争条件(race condition)。为了避免这种情况,我们需要使用锁来确保每个线程都能按照预期方式访问共享资源。 在C++中,常用的锁包括互斥锁(mutex)、读写锁(read-write lock)和条件变量(condition variable)。 互斥锁是最基本的锁,用于保护对共享资源的互斥访问。当一个线程获得了互斥锁后,其他线程就无法访问共享资源,直到该线程释放锁。互斥锁的使用方法如下: ```c++ #include <mutex> std::mutex m; void my_function() { std::lock_guard<std::mutex> lock(m); // 访问共享资源的代码 } ``` 这里使用了std::lock_guard类,它是一个RAII(资源获取即初始化)对象,用于自动获取和释放锁。在my_function函数中,当std::lock_guard对象被创建时,它会自动获取互斥锁;当my_function函数返回时,std::lock_guard对象会自动释放锁。 读写锁允许多个线程同时读取共享资源,但只允许一个线程写入共享资源。当一个线程获得了写锁时,其他任何线程都无法访问共享资源。当一个线程获得了读锁时,其他线程也可以获得读锁,但不能获得写锁。使用读写锁的方法如下: ```c++ #include <shared_mutex> std::shared_mutex m; void read_function() { std::shared_lock<std::shared_mutex> lock(m); // 读取共享资源的代码 } void write_function() { std::unique_lock<std::shared_mutex> lock(m); // 写入共享资源的代码 } ``` 这里使用了std::shared_lock类和std::unique_lock类,它们分别用于获取读锁和写锁。当std::shared_lock对象被创建时,它会自动获取读锁;当std::unique_lock对象被创建时,它会自动获取写锁。与互斥锁一样,这些锁也是RAII对象,会自动释放锁。 条件变量用于在线程之间传递信号,以便某个线程可以等待另一个线程发出的信号。条件变量通常与互斥锁一起使用。使用条件变量的方法如下: ```c++ #include <condition_variable> std::mutex m; std::condition_variable cv; void my_function() { std::unique_lock<std::mutex> lock(m); // 等待信号的代码 cv.wait(lock); // 收到信号后的代码 } void send_signal() { cv.notify_one(); } ``` 这里使用了std::condition_variable类,它用于等待信号和发送信号。在my_function函数中,当cv.wait(lock)被调用时,当前线程会被阻塞,直到收到信号;在send_signal函数中,cv.notify_one()用于发送一个信号,唤醒一个等待线程。与互斥锁和读写锁一样,std::unique_lock也是RAII对象,会自动释放锁。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值