java开发:JAVA多线程(八):读写锁ReadWriteLock

java开发中实现线程同步我们一般使用synchronize来修饰方法或者代码块,synchronize是一种互斥锁,只有一个线程能拿到锁。在实际开发中我们会有这么一种情况:多个线程同时读写,读线程的数量远远大于写线程。而我们知道读并不会导致数据出问题,只有写的时候才会需要同步。如果说我们使用synchronize来修饰则效率会很低,即使俩个线程同时读取数据必须要有一个线程进行等待。若我们只对写的方法上锁,读的方法不加锁的话。如果说有线程正在写数据,其他线程进入读取数据,造成的问题更大,因此只能使用synchronize对读写都加锁。

那么有没有一种锁可以实现读的时候可以多线程,写的时候只能有一个线程,并且读和写是互斥的,本文说到的ReadWriteLock就是一个读写锁,它一共有俩个锁,读锁和写锁。ReadWriteLockjava的一个接口,它的实现类是ReentrantReadWriteLock
读锁:是非互斥锁,允许多个线程得到
写锁:是互斥锁,只能一个线程得到
读锁和写锁是互斥的:例如线程1和线程2要读取数据需要获取读锁,如果此时写锁被线程3占用,则线程1和线程2需要等待线程3释放写锁后才能获取到读锁。反之如果线程1和线程2都在占用读锁,线程3若要写入数据则得等待线程1和线程2都释放完读锁才可以进行修改数据。
参考:多线程并发之读写锁(ReentranReadWriteLock&ReadWriteLock)使用详解

发布了194 篇原创文章 · 获赞 42 · 访问量 4万+

猜你喜欢

转载自blog.csdn.net/qq_39027256/article/details/103746151