JDK5以后提供了一个更加强大的线程同步机制—通过显式定义同步锁对象来实现同步,同步锁使用Lock对象。
ReentrantLock类实现了Lock,它拥有synchronized相同的并发性和内存语言,在实现线程安全的控制中,比较长使用的是ReentrantLock,可以加锁和释放锁。
我们可以通过简单的实现抢票来观察:
package com.yys;
import java.util.concurrent.locks.ReentrantLock;
public class TestLock {
public static void main(String[] args) {
TestLock2 testLock2 = new TestLock2();
new Thread(testLock2).start();
new Thread(testLock2).start();
new Thread(testLock2).start();
}
}
class TestLock2 implements Runnable{
int ticketNum = 10;
//定义一个lock锁
private final ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
while (true){
try {
//加锁
lock.lock();
if (ticketNum>0){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(ticketNum--);
}else{
break;
}
}finally {
lock.unlock();
}
}
}
}
ReentrantLock :可重复锁。
Lock和synchronized的对比?
- Lock时显式锁,需要手动开启关闭锁。synchronized是隐式锁,出了作用域就会自动释放。
- Lock只有代码块锁,synchronized有代码块锁和方法锁。
- 使用Lock锁,JVM调度线程的时间少,性能较好,提供了子类具有更好的扩展性。