您好,登錄后才能下訂單哦!
這篇文章主要介紹java如何實現多線程賣票功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
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;// 總的票數,這個是共享資源,多個線程都會訪問 public void run() { while (true)// 循環是指線程不停的去賣票 { synchronized (this)// 當操作的是共享數據時, // 用同步代碼塊進行包圍起來,執行里面的代碼需要mutex的鎖,但是mutex只有一個鎖。這樣在執行時,只能有一個線程執行同步代碼塊里面的內容 { if(ticketCount>0) { ticketCount--; System.out.println(Thread.currentThread().getName() + "正在賣票,還剩" + ticketCount + "張票"); } } /** * 在同步代碼塊里面睡覺,和不睡效果是一樣 的,作用只是自已不執行,也不讓線程執行。sleep不釋放鎖,抱著鎖睡覺。其他線程拿不到鎖,也不能執行同步代碼。wait()可以釋放鎖 * 所以把睡覺放到同步代碼塊的外面,這樣賣完一張票就睡一會,讓其他線程再賣,這樣所有的線程都可以賣票 */ try { Thread.sleep(100); } catch (InterruptedException e) { e.printStackTrace(); } } } }
這是賣票的經典案例,在這做個記錄。
以上是“java如何實現多線程賣票功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。