Java多线程的同步控制记录
一、重入锁
重入锁完全可以代替 synchronized 关键字。在JDK 1.5 早期版本,重入锁的性能优于 synchronized。JDK 1.6 开始,对于 synchronized 做了大量优化,使得两者性能差距不大。
代码示例:
private static ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
lock.lock(); // 加锁
try {
// doSomething
} finally {
lock.unlock(); // 释放锁
}
}
PS:因为重入锁需要我们手动加锁/释放锁,比较好实现对于逻辑的控制。
注意事项:
加锁后记得释放锁,否则其他线程就没有机会访问(比如,临界区资源)。
一个线程多次获得锁(其实是同一把锁)。但加了多少次锁,就要释放多少次锁。同时,lock()方法会一直堵塞线程直到释放锁。
中断响应 : lockInterruptibly()方法是一个可以对中断进行响应的锁申请动作(在等待锁的过程中,可以响应中断)。
锁申请等待限时 : tryLock()方法给定一个等待时间,让线程自动放弃等待,避免死锁(PS:当前线程会尝试获得锁,如果锁未被其他线程占用,则申请成功返回true;否则返回false)。
公平锁:
通过ReentrantLock(true)的构