线程的互斥锁
当我们访问一个资源,但是这个资源不能同时被访问的时候,我们可以使用线程的互斥锁来解决这个问题,当线程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为写锁
虽然两种情况的结果类似,但是可以自己通过实验看到,使用读锁程序中是共同一起读的,而写锁与互斥锁类似
总结
- 一个资源中,互斥锁存在,则不存在读写锁
- 一个资源中可以存在多个读写锁,但是只能存在一个互斥锁
- 互斥锁与其他锁都是互斥的(即不能边写边读)
- 读写锁的作用:当访问资源中,很多情况下都使用”读“操作,偶尔使用”写“操作,那么这个情况下就是使用读写锁。