在java多线程中,我们可以使用synchronized关键字来实现线程之间的同步互斥工作。还有一个更优秀的机制去完成这个“同步互斥”工作,就是Lock,主要学习两种一个是重入锁和读写锁。他们比synchronized功能更强大,并且还具有嗅探锁定、多路分支等功能。
- 重入锁 在需要同步的代码部分加上锁,但最后一定不要忘了释放锁,不然会造成锁永远无法释放。一般使用Lock时配合try和finally
在使用synchronized时,多线程协同工作必须配合wait()和notify()、notifyAll()协同使用, 在使用Local的时候可以使用一个新的等待/通知的类,他就是Condition,这个condition一定是针对某一把锁的,也就是说只有锁的基础上才能产生condition condition的await()阻塞方法,和signal()方法。 一个Lock能创建多个condition进行多线程之间的交互,可以使得部分线程唤醒signalAll(),部分线程等待, Lock lock = new ReentrantLock() 创建锁的时候可以指定公平锁和非公平锁,公平锁就是按照代码的顺序进行加锁,非公平锁效率略高于公平锁 Lock 用法 tryLcok尝试获得锁,返回true/false。好处是不用等待了,也可以设置在指定的时间内获得尝试获得锁,同样返回true/false isFair 是否是公平锁 isLocked是否锁定
2.读写锁 ReenTrantReadWriteLock,起核心就是实现读写分离的锁,在高并发的尤其是读多写少性能远高于重入锁. 实际上是两个锁,一个是读的锁,一个是写的锁 口诀 : 读读共享 写写互斥 读写互斥