使用标准库std,进行加锁,同样能处理异常时,能正确离开的问题
class Counter
{
public:
Counter() : m_count(0),m_count2(0) {}
~Counter() {}
void addcount() {
std::lock_guard<std::mutex> lock(m_muter);// 这样子定义,则整个函数会加锁,解锁
m_count++;
}
void addcount2() {
std::lock_guard<std::mutex> lock(m_muter);// 这样子定义,则整个函数会加锁,解锁
m_count2++;
}
int Getcount() const {
if (m_count % 50000 == 0)
{
std::cout << "m_count 被 5000 整除" << std::endl;
return 0;
}
return 1;
}
int Getcount2() const {
if (m_count2 % 10000 == 0)
{
std::cout << "Getcount2 被 10000 整除" << std::endl;
return 0;
}
return 1;
}
int Get1() const {
return m_count;
}
int Get2() const{
return m_count2;
}
private:
int m_count;
int m_count2;
std::mutex m_muter; // mutable的中文意思是“可变的,易变的”,跟constant(既C++中的const)是反义词。
// 我们知道,如果类的成员函数不会改变对象的状态,那么这个
C++ 11 多线程 mutex (二) 利用标准库进行加锁
最新推荐文章于 2024-09-23 11:39:12 发布
本文详细探讨了C++11中的多线程加锁机制,重点介绍了如何利用标准库中的mutex实现线程同步。通过实例解析了mutex的使用方法,包括互斥锁、条件变量等,确保线程安全并避免数据竞争。
摘要由CSDN通过智能技术生成