吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1293|回复: 4
收起左侧

[讨论] 学习C++的第十九天 线程2

[复制链接]
博弟弟丶 发表于 2021-4-27 18:28
本帖最后由 博弟弟丶 于 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;

};

免费评分

参与人数 3吾爱币 +3 热心值 +3 收起 理由
debug_cat + 1 + 1 谢谢@Thanks!
Noyi + 1 + 1 热心回复!
a2315534 + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

a2315534 发表于 2021-4-27 18:34
先马克后看
BaconOle 发表于 2021-4-27 18:58
加油,不过你这个锁加的没用,因为你传的变量a既不是指针也不是引用,所以两个线程里修改的这个变量是不同的。
g53633509 发表于 2021-4-27 20:39
 楼主| 博弟弟丶 发表于 2021-4-27 21:17
BaconOle 发表于 2021-4-27 18:58
加油,不过你这个锁加的没用,因为你传的变量a既不是指针也不是引用,所以两个线程里修改的这个变量是不同 ...

多谢大佬的指点
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 03:32

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表