Lock接口和synchronized的比较
- Lock是一个接口,而synchronized是java的一个关键字。
- Lock适用于以下场景:获取锁可以被中断interrupt,超时获取锁,尝试获取锁trylock,读多写少用读写锁。而synchronized就不是可中断锁。
- synchronized和ReentrantLock都是可重入锁。
- Lock一定要将同步代码块用try catch包起来,finally中用unlock释放锁,避免死锁的发生。synchronized在发生异常时候会自动释放占有的锁,因而避免死锁的发生。
重入锁
某个线程可以多次进入拿到同一个锁,比如在递归方法中等。
公平锁和非公平锁
- 公平锁:在时间上,先对锁进行获取的请求,一定先被满足,这个锁就是公平的。
- 非公平锁:在时间上,等待时间最长的不一定能先获取到锁。举例:A线程拿到锁,B线程拿锁时,没有获取到,于是B线程被挂起(让出CPU资源)。当线程A释放锁,刚好C线程也来拿锁,C线程比挂起的B线程先拿到锁(从挂起到获取CPU资源也是需要时间的)。这就是非公平锁。这点就显示出:非公平锁的性能比公平锁高。
ReentrantLock接口和ReentrantReadWriteLock读写锁
- ReentrantLock和Syn关键字,都是排他锁;
- ReentrantReadWriteLock:同一时刻允许多个读线程同时访问,但是写线程访问的时候,所有的读和写都被阻塞,最适宜与读多写少的情况。