java實現(xiàn)多線程賣票功能
更新時間:2019年07月15日 08:38:43 作者:jhhuang4836
這篇文章主要為大家詳細介紹了java實現(xiàn)多線程賣票功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
java多線程賣票直接先看個例子:
public class SelTicketsMainTest { public static void main(String[] args) { SaleTickets1 saleTickets = new SaleTickets1(); for(int t=1;t<=3;t++) { new Thread(saleTickets).start(); } } } class SaleTickets1 implements Runnable{ private int ticketCount = 10;// 總的票數(shù),這個是共享資源,多個線程都會訪問 public void run() { while (true)// 循環(huán)是指線程不停的去賣票 { synchronized (this)// 當操作的是共享數(shù)據(jù)時, // 用同步代碼塊進行包圍起來,執(zhí)行里面的代碼需要mutex的鎖,但是mutex只有一個鎖。這樣在執(zhí)行時,只能有一個線程執(zhí)行同步代碼塊里面的內(nèi)容 { if(ticketCount>0) { ticketCount--; System.out.println(Thread.currentThread().getName() + "正在賣票,還剩" + ticketCount + "張票"); } } /** * 在同步代碼塊里面睡覺,和不睡效果是一樣 的,作用只是自已不執(zhí)行,也不讓線程執(zhí)行。sleep不釋放鎖,抱著鎖睡覺。其他線程拿不到鎖,也不能執(zhí)行同步代碼。wait()可以釋放鎖 * 所以把睡覺放到同步代碼塊的外面,這樣賣完一張票就睡一會,讓其他線程再賣,這樣所有的線程都可以賣票 */ try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } } } }
這是賣票的經(jīng)典案例,在這做個記錄。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot中Controller的傳參方式詳細講解
這篇文章主要介紹了SpringBoot在Controller層接收參數(shù)的常用方法,Controller接收參數(shù)的常用方式總體可以分為三類,第一類是Get請求通過拼接url進行傳遞,第二類是Post請求通過請求體進行傳遞,第三類是通過請求頭部進行參數(shù)傳遞,下面我們來詳細看看2023-01-01基于java swing實現(xiàn)答題系統(tǒng)
這篇文章主要為大家詳細介紹了基于java swing實現(xiàn)答題系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01Spring?Boot中的max-http-header-size配置方式
這篇文章主要介紹了Spring?Boot中的max-http-header-size配置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09