初识Linux · 线程互斥

前言:

本文的主题是线程互斥,但是我们不能光单独的把概念引出来,我们肯定要一个场景,所以我们将抢票这个场景引出来,模拟一下抢票的场景,随即引出今天的主题。

那么对于线程互斥这个主题,我们从以下几点介绍:

认识锁和它的接口->解决历史问题->原理角度理解锁->实现角度理解锁。

当然了,因为没有理解抢票这个场景,所以我们暂时不知道锁是什么是正常的,那么,直接进入主题吧!


场景->抢票

抢票的基本逻辑是多个线程一起抢,所以我们需要创建多线程,多线程创建好了之后,都执行同一个函数,即抢票函数。

同时,我们将票的数量固定到只有10000张,让4个线程在规定时间之内抢票,因为cpu里面存在时间片的概念,所以我们不妨设置一个死循环,一个线程在规定时间之内能抢多少就抢多少。

基本逻辑我们已经捋顺了,现在直接实现吧!

代码语言:JavaScript代码运行次数:0运行复制

int tickets = 10000;void Rounte(const std::string& name){    while(true)    {        if(tickets > 0)        {            usleep(1000);            printf("who: %s, get a ticket: %dn", 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 · 线程互斥

抢到了负数?

抢到了相同的票?

© 版权声明
THE END
喜欢就支持一下吧
点赞12 分享