多线程买票,用synchronized和lock两种方法
用了线程池,注意线程池用完要关闭,不然程序结束不了。
public class ThreadDemo4 {
public static void main(String[] args){
MyRunnable5 mr5 = new MyRunnable5();
ExecutorService executorService = Executors.newFixedThreadPool(8);
for (int i = 0; i < 3; i++) {
executorService.execute(mr5);
}
executorService.shutdown();
// Thread t1 = new Thread(mr5);
// Thread t2 = new Thread(mr5);
// t1.start();
// t2.start();
return;
}
}
class MyRunnable5 implements Runnable{
private int ticket = 10; //售票
private Object obj = new Object();//锁
@Override
public void run() {
for (int i = 0; i < 15; i++) {
// synchronized (this){
// if (ticket > 0){
// ticket--;
// try {
// Thread.sleep(300);
// } catch (InterruptedException e) {
// e.printStackTrace();
// }
// System.out.println("您购买的票剩余:"+ticket + "张");
// }
method();
//method2();
}
}
//同步方法:同步的对象是当前对象
private synchronized void method() {
if (ticket > 0) {
ticket--;
try {
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("您购买的票剩余:" + ticket + "张");
}
}
//互斥锁
ReentrantLock lock = new ReentrantLock();
//lock实现同步
private void method2() {
lock.lock();//锁
try {
if (ticket > 0) {
ticket--;
try {
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("您购买的票剩余:" + ticket + "张");
}
} finally {
lock.unlock();//由代码去决定锁的作用范围,通过条件去实现释放锁,更加灵活
}
}
}