C++11 mutex方便的自解锁lock_guard

本文通过实例介绍了C++中mutex的基本使用方法,并重点讲解了std::lock_guard的用途及其如何与mutex配合使用来简化线程同步操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



下面是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(); 
}

重点介绍的不是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解锁。
这个功能在函数体比较长,尤其是存在多个分支的时候很有用。
 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值