JDK 5.0以后新增了Lock用来实现线程安全。
注意:
- Lock是一个接口,我们常用它的实现类ReentrantLock。
- 需要手动调用lock()上锁,unlock()解锁。
代码实现:
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* @description lock实现线程安全购票
* @author panghu
*
*/
public class LockTest1 {
public static void main(String[] args) {
Window w = new Window();
Thread t1 = new Thread(w);
Thread t2 = new Thread(w);
Thread t3 = new Thread(w);
t1.setName("窗口1");
t2.setName("窗口2");
t3.setName("窗口3");
t1.start();
t2.start();
t3.start();
}
}
class Window implements Runnable {
private int ticket = 100;
// 实例化对象 Lock是个接口,我们实例化Lock的实现类ReentrantLock
// 其中ReentrantLock有孔灿构造器和带fair参数的构造器 为true表示公平分配资源 默认为false
Lock lock = new ReentrantLock();
@Override
public void run() {
// TODO Auto-generated method stub
while (true) {
// 上锁
lock.lock();
try {
if (ticket > 0) {
System.out.println(Thread.currentThread().getName() + ":" + ticket--);
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
} else {
break;
}
} catch (Exception e) {
e.printStackTrace();
} finally {
// 解锁
lock.unlock();
}
}
}
}

本文介绍了JDK5.0引入的Lock接口及其实现类ReentrantLock,通过一个线程安全的售票窗口示例展示了如何使用Lock进行手动锁释放,以确保并发控制的精确性和效率。在示例中,多个线程通过获取和释放锁来避免票数的不一致问题。
2818

被折叠的 条评论
为什么被折叠?



