本帖最后由 博弟弟丶 于 2021-4-27 18:30 编辑
[C++] 纯文本查看 复制代码 #include <iostream>
#include <thread>//线程库 创建线程用的
#include <mutex>//互斥量库 互斥量是为了解决数据共享过程中可能存在的访问冲突的问题。
using namespace std;
std::mutex m; //实例化m对象
void huchi(int a) {
//m.lock();//简单一点就是上锁 //当代码量大的时候 不建议使用lock 和unlock 可以使用lock_guard<mutex> g1(m)
std::lock_guard<mutex>g1(m);//职责就是帮你管理互斥量,就好像小孩要玩玩具时候,保姆就帮忙把玩具找出来,孩子不玩了,保姆就把玩具收纳好。
cout << "huchi函数正在改写a" << endl;//
cout << "原始a为" << a << endl;//在互斥量锁定到互斥量解锁之间的代码叫做临界区
cout << "现在的a为" << a + 2 << endl;//
//m.unlock();//简单一点说就是解锁 //当代码量大的时候 不建议使用lock 和unlock
};
void huchi1(int a) {
std::lock_guard<mutex>g2(m);
//m.lock();//简单一点就是说上锁 ////当代码量大的时候 不建议使用lock 和unlock
cout << "huchi1函数正在改写a" << endl;//
cout << "原始a为" << a << endl;//在互斥量锁定到互斥量解锁之间的代码叫做临界区
cout << "现在的a为" << a + 1 << endl;//
//m.unlock();//简单一点说就是解锁 ////当代码量大的时候 不建议使用lock 和unlock
};
int main() {
int a = 0;
std::thread xc1(huchi, a);//线程1 有一个问题就是他会先执行线程2 而不是线程1 这是因为线程执行他是不固定的
std::thread xc2(huchi1, a);//线程2 顺便介绍了有参数的函数 该如何写
xc1.join();//等待线程1
xc2.join();//等待线程2
return 0;
}; |