【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); 

【Linux学习笔记45】线程的互斥锁与读写锁_第1张图片
代码运行结果
pro2没有互斥锁,会出现数据混乱
pro1有互斥锁,但是ab出现的情况并不是如图所示,而是谁先到谁先有互斥锁的权力
【Linux学习笔记45】线程的互斥锁与读写锁_第2张图片

线程的读写锁(共享锁)

刚刚的互斥锁例子是两个线程的情况,如果是进程中存在多个线程的情况下,互斥锁的弊端还是很多的。举个例子:进程中有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);

【Linux学习笔记45】线程的互斥锁与读写锁_第3张图片
程序运行结果:
pro2为读锁,pro1为写锁
【Linux学习笔记45】线程的互斥锁与读写锁_第4张图片
【Linux学习笔记45】线程的互斥锁与读写锁_第5张图片
虽然两种情况的结果类似,但是可以自己通过实验看到,使用读锁程序中是共同一起读的,而写锁与互斥锁类似

总结

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

你可能感兴趣的:(Linux操作系统,Linux学习笔记,线程)