/**
* 出现安全隐患的原因:
* 一个线程在进行操作的时候,其它线程也参与了运算
* 解决办法:
* 将共享的代码块进行封装,只有当当前线程使用完后其它线程才可以使用
* 关键词:synchronized 同步锁
* synchronized(对象){
* 共享代码块
* }
* 同步锁的好处和弊端:
* 好处:解决了线程安全问题
* 弊端:同步之外的其它线程每次都需要判断同步锁,降低了效率
* 什么时候使用同步锁?
* 考虑安全性问题,在同步中多个线程需要使用同一个锁的时候
*/
package xiancheng;
public class saleNoTwo {
public static void main(String[] args) {
Ticke ticke = new Ticke();
Thread t1 = new Thread(ticke,"张三");
Thread t2 = new Thread(ticke,"李四");
Thread t3 = new Thread(ticke,"王五");
t1.start();
t2.start();
t3.start();
}
}
class Ticke implements Runnable{
private int num =100;
Object obj = new Object();
@Override
public void run() {
while (true) {
//**********************这是有序的***************************************
show();
show2(); //show和show2只能调用一个执行,因为这是执行的同一个方法
//*************************这是无序无序的****************************************
/*if(num>0){
System.out.println(Thread.currentThread().getName()+"-剩余票数:"+(--num));
}*/
//********************************************************************
}
}
public void show() {
synchronized (obj) {
if(num>0){
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"-剩余票数:"+(--num));
}
}
}
public void show2() {
this.show();
}
}