前言:
本文的主题是线程互斥,但是我们不能光单独的把概念引出来,我们肯定要一个场景,所以我们将抢票这个场景引出来,模拟一下抢票的场景,随即引出今天的主题。
那么对于线程互斥这个主题,我们从以下几点介绍:
认识锁和它的接口->解决历史问题->原理角度理解锁->实现角度理解锁。
当然了,因为没有理解抢票这个场景,所以我们暂时不知道锁是什么是正常的,那么,直接进入主题吧!
场景->抢票
抢票的基本逻辑是多个线程一起抢,所以我们需要创建多线程,多线程创建好了之后,都执行同一个函数,即抢票函数。
同时,我们将票的数量固定到只有10000张,让4个线程在规定时间之内抢票,因为cpu里面存在时间片的概念,所以我们不妨设置一个死循环,一个线程在规定时间之内能抢多少就抢多少。
基本逻辑我们已经捋顺了,现在直接实现吧!
豆包AI编程
豆包推出的AI编程助手
483 查看详情
代码语言:javascript代码运行次数:0运行复制
int tickets = 10000;void Rounte(const std::string& name){ while(true) { if(tickets > 0) { usleep(1000); printf("who: %s, get a ticket: %d\n", name.c_str(), tickets); tickets--; } else { break; } }}int main(){ Thread t1("thread -1", Rounte); Thread t2("thread -2", Rounte); Thread t3("thread -3", Rounte); Thread t4("thread -4", Rounte); t1.Start(); t2.Start(); t3.Start(); t4.Start(); t1.Join(); t2.Join(); t3.Join(); t4.Join(); return 0;}
当然了,使用的线程是我们自己实现的线程,使用起来还是比较丝滑的。
那么我们认为的现象应该是最后tickets到了0,循环结束,整个代码完美结束。
不过……?

抢到了负数?
抢到了相同的票?
以上就是初识Linux · 线程互斥的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/490258.html
微信扫一扫
支付宝扫一扫