重入锁可以完全替代synchronized关键字,在JDK 5.0早期版本中,重入锁的性能远远好于synchronzied,但是在6.0之后在synchronzied上做了大量的优化,使两者的差距并没那么大的差别。
重入锁使用java.util.concurrent.locks.ReentrantLock类来实现,它只是一个类;
且看如下代码:
package cn.yan.current;
import java.util.concurrent.locks.ReentrantLock;
public class ReenterLock implements Runnable {
private static ReentrantLock lock = new ReentrantLock();
public static int i = 0;
@Override
public void run() {
for (int j = 0; j < 30000; j++) {
lock.lock();
try {
i++;
} finally {
lock.unlock();
}
}
}
public static void main(String[] args) throws InterruptedException {
ReenterLock reenterLock = new ReenterLock();
Thread t1 = new Thread(reenterLock);
Thread t2 = new Thread(reenterLock);
Thread t3 = new Thread(reenterLock);
t1.start();
t2.start();
t3.start();
t1.join();
t2.join();
t3.join();
System.out.println("i ====>>>> " + i);
}
}
最终其结果会是什么?显而易见,为90000.
上述代码使用重入锁保护临界区资源i,确保多线程时对i的操作的安全性。从这段代码可以看出,与synchronzied关键字相比,重入锁需要程序员手动的获取锁和释放锁资源。