【Linux学习笔记45】线程的互斥锁与读写锁

线程的互斥锁

当我们访问一个资源,但是这个资源不能同时被访问的时候,我们可以使用线程的互斥锁来解决这个问题,当线程1要访问资源的时候,加入互斥锁,防止线程2或者其他线程同时访问该资源

代码的实现

1.定义互斥锁:

pthread_mutex_t  m;

2.初始化互斥锁:

pthread_mutex_init(&m,NULL); 

3.使用互斥锁(上锁)

pthread_mutex_lock(&m);

4.使用互斥锁(解锁)

pthread_mutex_unlock(&m); 

在这里插入图片描述
代码运行结果
pro2没有互斥锁,会出现数据混乱
pro1有互斥锁,但是ab出现的情况并不是如图所示,而是谁先到谁先有互斥锁的权力
在这里插入图片描述

线程的读写锁(共享锁)

刚刚的互斥锁例子是两个线程的情况,如果是进程中存在多个线程的情况下,互斥锁的弊端还是很多的。举个例子:进程中有30个线程,其中一个线程要对资源进行“写”操作,那么这个时候可以使用互斥锁,不允许其他进程写入。但是如果是线程的“读"操作,可以允许多个线程同时读,那么这时候就不能使用互斥锁,而是要用读写锁(共享锁)。

代码的实现

1.定义读写锁

pthread_rwlock_t rwlock;

2.初始化读写锁

pthread_rwlock_init(&rwlock,NULL); 

3.使用读写锁

pthread_rwlock_rdlock(&rwlock); 

使用写锁

pthread_rwlock_wrlock(&rwlock); 

4.解锁

pthread_rwlock_unlock(&rwlock);

在这里插入图片描述
程序运行结果:
pro2为读锁,pro1为写锁
在这里插入图片描述
在这里插入图片描述
虽然两种情况的结果类似,但是可以自己通过实验看到,使用读锁程序中是共同一起读的,而写锁与互斥锁类似

总结

  • 一个资源中,互斥锁存在,则不存在读写锁
  • 一个资源中可以存在多个读写锁,但是只能存在一个互斥锁
  • 互斥锁与其他锁都是互斥的(即不能边写边读)
  • 读写锁的作用:当访问资源中,很多情况下都使用”读“操作,偶尔使用”写“操作,那么这个情况下就是使用读写锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值