这节我们讨论怎样使用mutex锁保护多线程环境中的共享数据来避免竞争条件
为了修复多线程环境中的竞争条件,我们需要mutex互斥锁,在修改或读取共享数据前,需要对数据加锁,修改完成后,对数据进行解锁。
在c++11的线程库中,mutexes在<mutexe>头文件中,表示互斥体的类是std::mutex。
mutex有两个重要的方法:
1.) lock()
为了修复多线程环境中的竞争条件,我们需要mutex互斥锁,在修改或读取共享数据前,需要对数据加锁,修改完成后,对数据进行解锁。
在c++11的线程库中,mutexes在<mutexe>头文件中,表示互斥体的类是std::mutex。
mutex有两个重要的方法:
1.) lock()
2.) unlock()
在上一节中,我们使用了一个多线程类Wallet解释了竞争条件:c++11多线程编程(四):数据共享和竞争条件
这一节,我们在多线程类Wallet中使用mutex来避免竞争条件。
Wallet类提供了在Wallet中增加money的方法,并且在不同的线程中使用相同的Wallet对象,所以我们需要对Wallet的addMoney()方法加锁。
在增加Wallet中的money前加锁,并且在离开该函数前解锁,看代码:
Wallet类内部维护money,并提供函数addMoney(),这个成员函数首先获取一个锁,然后给wallet对象的money增加指定的数额,最后释放锁
#include <iostream>
#include <thr