linux下多线程编程入门(三)

前面两节粗略学习了一下多线程编程,这一节我们来了解一下锁的概念。
由于多线程之间是并发执行的,而系统调度又是随机的,因此在写多线程程序时会出现很多问题,这时就免不了要用到各种锁机制来保证线程安全且按我们的意愿正确执行。

多线程可能出现的问题

当多个线程同时读写同一块代码区的时候,就出现很多问题。
比如初始i=0;我们希望线程1和线程2各执行一次i++;理想结果是i=2;

但是线程1执行 i++; 此时应该 i=1;
但是线程2正好同时读取到了i=0;自加后i=1;然后把i=1复制给i。
这不是我们希望看到的 这时候我们就要用到锁。

#include <stdio.h>
#include<stdlib.h>
#include<pthread.h>

int s=0;

void *test(void* args)
{
    int i=0;
    for(i=0;i<100000;i++)
    s++;
}
int main()
{
    pthread_t th1;
     pthread_t th2;
    pthread_create(&th1,NULL,test,NULL);
     pthread_create(&th2,NULL,test,NULL);
    pthread_join(th1,NULL);//等待线程TH执行完
    pthread_join(th2,NULL);//等待线程TH1执行完
     printf("s=%d\n",s);
    printf("\n");
    return 0;
}

如同上面这段代码,理想情况下s=200000;但是输出结果相差很大,而且每次都不一样,这和CPU的状态有关。
在这里插入图片描述

锁的概念

就好比厕所单间,一个人进入锁上门后,使用完厕所,出来之后,另一个人才能进入。

锁就是当一个 线程读写一段代码块时,给这段代码块上锁,不允许其他线程访问,其他线程要先在外面等待。

#include <stdio.h>
#include<stdlib.h>
#include<pthread.h>

int s=0;
pthread_mutex_t lock;//定义互斥锁 lock
void *test(void* args)
{
    
    int i=0;
     
    for(i=0;i<100000;i++)
    {
        pthread_mutex_lock(&lock);//此处安锁
    s++;
      pthread_mutex_unlock(&lock);//此处解锁
    }
  
}
int main()
{
    pthread_t th1;
     pthread_t th2;

    pthread_mutex_init(&lock,NULL);//初始化锁

    pthread_create(&th1,NULL,test,NULL);
     pthread_create(&th2,NULL,test,NULL);

    pthread_join(th1,NULL);//等待线程TH执行完
    pthread_join(th2,NULL);//等待线程TH1执行完

     printf("s=%d\n",s);
    printf("\n");
    return 0;
}

运行结果
在这里插入图片描述

但是这个代码重复的上锁解锁,代码执行时间会变慢很多。
可以使用 time ./test1查看运行时间
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值