C++11 mutex方便的自解锁lock_guard
C++11 mutex方便的自解锁lock_guard
道友慢走 发表于5年前
C++11 mutex方便的自解锁lock_guard
  • 发表于 5年前
  • 阅读 12560
  • 收藏 4
  • 点赞 0
  • 评论 0

【腾讯云】买域名送云解析+SSL证书+建站!>>>   

C++11 中新增了mutex.用法就是简单的lock,unlock

下面是cpprefrence里的使用mutex的代码。

#include <iostream> #include <map> #include <string> #include <chrono> #include <thread> #include <mutex>   std::map<std::string, std::string> g_pages; std::mutex g_pages_mutex;   void save_page(const std::string &url) {     // simulate a long page fetch     std::this_thread::sleep_for(std::chrono::seconds(2));     std::string result = "fake content";       g_pages_mutex.lock();     g_pages[url] = result;     g_pages_mutex.unlock(); }   int main() {     std::thread t1(save_page, "http://foo");     std::thread t2(save_page, "http://bar");     t1.join();     t2.join();       g_pages_mutex.lock(); // not necessary as the threads are joined, but good style     for (const auto &pair : g_pages) {         std::cout << pair.first << " => " << pair.second << '\n';     }     g_pages_mutex.unlock(); }     t2.join(); } 
重点介绍的不是mutex。是std::lock_guard。这东西是干什么的呢?它是与mutex配合使用,把锁放到lock_guard中时,mutex自动上锁,lock_guard析构时,同时把mutex解锁。

把先看一段简单代码。

#include <thread> #include <mutex>   int g_i = 0; std::mutex g_i_mutex;  // protects g_i   void safe_increment() {     std::lock_guard<std::mutex> lock(g_i_mutex);     ++g_i;       // g_i_mutex is automatically released when lock     // goes out of scope }   int main() {     std::thread t1(safe_increment);     std::thread t2(safe_increment);       t1.join();     t2.join(); } 
std::lock_guard是一个局部变量,创建时,g_i_mutex 上锁,析构时g_i_mutex解锁。这个功能在函数体比较长,尤其是存在多个分支的时候很有用。

C++的功能越来越丰富,忍不住想起了候JJ说的:很多软件产品会越来越往流水线的发展,越来越低的门槛,越来越简单的使用。。。


标签: mutex lock_guard C++11
  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 4
博文 19
码字总数 6209
×
道友慢走
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: