package cn.dali3.code03;
/*线程安全问题解决方法第一种:
同步代码块
* 格式:synchronized(同步锁){
* 同步代码
* }
* 注意:
* 同步锁可以使用任意对象,但每个线程使用的对象必须一致
* 锁对象的作用:
* 把同步代码锁住,只要一个线程在里面执行,当这个线程全部执行完毕后,其他线程才可以执行
*
* 原理:
* 第一个线程碰到了synchronized,首先检查有没有锁对象,如果有锁对象,进入代码块中
* 直到代码块中的程序执行完毕后出来,归还锁对象。
* 当第一个线程进入后,第二个线程抢到了cpu的执行权,准备进入代码块,但检测到没有锁对象
* 则会处于一种阻塞状态,直到有锁对象后才会进入同步代码块中
*
* 注:频繁的判断锁,获取锁,释放锁会降低程序运行效率*/
public class Demo02 {
public static void main(String[] args) {
Runnable run = new RunnableImpl();
Thread th0 = new Thread(run);//创建第一个窗口
Thread th1 = new Thread(run);//创建第二个窗口
Thread th2 = new Thread(run);//创建第三个窗口
th0.start();
th1.start();
th2.start();
}
}
接口实现类:
package cn.dali3.code03;
public class RunnableImpl implements Runnable {
private int ticket = 100;
Object obj = new Object();
@Override
public void run() {
while (true) {
synchronized (obj){
if (ticket > 0) {
try {
Thread.currentThread().sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"窗口"+"正在卖第"+ticket+"张票");
ticket--;
}
}
}
}
}