前言:
对于非计算机专业出身的朋友来说,很少会接触到读写锁这个高级概念,一般都只是使用到互斥量这一层。那么为什么有了互斥量(互斥锁)之后,还要发明读写锁呢?
结论:
读写锁是效率更高的互斥量(在大多数条件下)。
理由:
读写锁分为三种状态
1,以读的方式占据锁的状态。此时,如果有另外线程请求以读的方式占据锁,那么不会阻塞,可以再次占据。如果有另外线程请求以写的方式占据锁,那么会阻塞,直到以读的方式占据锁的线程释放锁。特别的,如果某线程以读方式占据锁后,既有线程请求以读的方式占据锁,也有线程请求以写的方式占据锁,那么以读方式请求锁的线程也同样会被阻塞,从而使得以写方式请求的线程能够率先占据锁,避免写线程一直等待。
2,以写的方式占据锁的状态。此时,所有请求占据锁的线程都会被阻塞,不论是以什么方式请求加锁。
3,尚未有线程占据锁的状态。此时,按照操作系统调度顺序依次占据锁。
试用场景:
对于共享资源,更多的是读取操作的情况下,适合使用读写锁。