java开发中实现线程同步我们一般使用
synchronize
来修饰方法或者代码块,synchronize
是一种互斥锁,只有一个线程能拿到锁。在实际开发中我们会有这么一种情况:多个线程同时读写,读线程的数量远远大于写线程。而我们知道读并不会导致数据出问题,只有写的时候才会需要同步。如果说我们使用synchronize
来修饰则效率会很低,即使俩个线程同时读取数据必须要有一个线程进行等待。若我们只对写的方法上锁,读的方法不加锁的话。如果说有线程正在写数据,其他线程进入读取数据,造成的问题更大,因此只能使用synchronize
对读写都加锁。
那么有没有一种锁可以实现读的时候可以多线程,写的时候只能有一个线程,并且读和写是互斥的,本文说到的
ReadWriteLock
就是一个读写锁,它一共有俩个锁,读锁和写锁。ReadWriteLock
是java
的一个接口,它的实现类是ReentrantReadWriteLock
读锁:是非互斥锁,允许多个线程得到
写锁:是互斥锁,只能一个线程得到
读锁和写锁是互斥的:例如线程1和线程2要读取数据需要获取读锁,如果此时写锁被线程3占用,则线程1和线程2需要等待线程3释放写锁后才能获取到读锁。反之如果线程1和线程2都在占用读锁,线程3若要写入数据则得等待线程1和线程2都释放完读锁才可以进行修改数据。
参考:多线程并发之读写锁(ReentranReadWriteLock&ReadWriteLock)使用详解