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


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

std::map 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  
#include    
int g_i = 0; 
std::mutex g_i_mutex;  // protects g_i   
void safe_increment() 
{     
std::lock_guard 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解锁。
这个功能在函数体比较长,尤其是存在多个分支的时候很有用。

你可能感兴趣的:(stl,C/C++)