线程--之售票

/**
* 出现安全隐患的原因:
* 一个线程在进行操作的时候,其它线程也参与了运算
* 解决办法:
* 将共享的代码块进行封装,只有当当前线程使用完后其它线程才可以使用
* 关键词: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();
}

}

猜你喜欢

转载自blog.csdn.net/weixin_39816332/article/details/77867802
今日推荐