- 从JDK1.5开始,Java提供了更强大的线程同步机制-通过显式定义同步锁对象来实现同步。同步锁使用Lock对象充当;
- Java.util.concurrent.locks.lock 接口是控制多个线程对共享资源进行访问的工具,锁提供了对共享资源的独占访问,每次只能有一个线程对Lock对象加锁,线程开始访问了共享资源之前的应先获得Lock对象;
- ReentrantLock类实现了Lock,它拥有与synchronized相同的并发性和内存语义,在实现线程安全的控制中,比较常用的是ReentrantLock,可以显示加锁,释放锁;
代码如下:也是很好诠释了什么事显式锁,什么事隐式锁
package Lock;
import java.util.concurrent.locks.ReentrantLock;
class buyTick implements Runnable {
int tickNum = 10;
private final ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
while (true) {
try {
lock.lock();
if (tickNum > 0) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(tickNum--);
} else {
break;
}
} finally {
lock.unlock();
}
}
}
}
public class lock {
public static void main(String[] args) {
buyTick buyTick = new buyTick();
new Thread(buyTick).start();
new Thread(buyTick).start();
new Thread(buyTick).start();
}
}
synchronized 与 lock(可重入锁)利弊分析
- Lock是显示锁,synchronized是隐式锁(出了作用域自动释放)
- lock只有代码块锁,synchronized有代码块锁和方法锁;
- 使用Lock锁,jvm将花费较少的时间来调度线程,性能更好,并且具有更好的扩展性(提供更多的子类);
- 优先使用顺序:Lock > 同步代码块 > 同步方法