面试题——读写锁,共享锁,排它锁

什么是读写锁(ReentrantReadWriteLock)?

  • 读写锁维护了一对锁,一个读锁和一个写锁,读锁是一个共享锁,写锁是一个排它锁,在读操作时获取读锁,写操作时获取写锁。
  • 当写锁被获取到时,其他线程的读写操作都会被阻塞。当读锁被获取到时,其他线程的读操作不会被阻塞,但写操作会被阻塞。
  • 读写锁支持非公平锁和公平锁;支持锁降级,即写锁可以降级为读锁,指首先维持住当前拥有的写锁,再获取到读锁,随后释放写锁的过程。

共享锁(读锁): 共享锁就是允许多个线程同时获取一个锁,一个锁可以同时被多个线程拥有。若事务T对数据对象A加上共享锁,则事务T可以读A但不能修改A,其他事务只能再对A加共享锁,而不能加排它锁,直到T释放A上的共享锁。这保证了其他事务可以读A,但在T释放A上的锁之前不能对A做任何修改。

排它锁(写锁): 排它锁,指一个锁在某一时刻只能被一个线程占有,其它线程必须等待锁被释放之后才可能获取到锁。若事务T对数据对象A加上排它锁,事务T可以读A也可以修改A,其他事务不能再对A加任何锁,直到T释放A上的锁。这保证了其他事务在T释放A上的锁之前不能再读取和修改A。

ReentrantLock就是一种排它锁。CountDownLatch是一种共享锁。

面试题——读写锁,共享锁,排它锁_第1张图片

你可能感兴趣的:(多线程)