標籤:
本文採用java多線程實現了類比車站多個車票賣票的功能。
關鍵詞:java多線程 共用變數 實現runnable介面 volatile 線程同步。
代碼如下
Ticket類
package ex7_TicketSaler;/*同一對象的多個線程thread0/1/2,對共用變數count的操作,需要將count的值聲明為volatile * 並且因為多個線程操作的是同一個對象ticket,因此count是資源共用的 * */public class Ticket implements Runnable{ volatile int count = 1000; //總共的票數量 Boolean flag = true; Object locObj = new Object(); @Override public void run() { // TODO Auto-generated method stub //加入同步塊後,count的值不會出現錯誤 while(count>0) {// synchronized(locObj)// {// // // // } getTicket(); } //線程結束後的處理常式 System.out.println(Thread.currentThread().getName()+"執行結束\n"); } //定義了一個同步方法 此方法同時只能被一個線程執行完畢後,另一個線程才能夠執行 public synchronized void getTicket() { if(count>0) { count--; System.out.println(Thread.currentThread().getName()+"賣出一張票,"+"剩餘票數:"+count +"\n"); Thread.yield(); } else { flag = false; } } }
TicketSaler類
package ex7_TicketSaler;public class TicketSaler { public static void main(String[] args) { // TODO Auto-generated method stub System.out.println("開始售票\n"); int n = 10; Thread [] threads= new Thread[n]; Ticket ticket = new Ticket(); for (int i=0;i<n;i++) { threads[i] = new Thread(ticket); threads[i].setName("售票視窗"+i); threads[i].start(); }// for(int i=0;i<n;i++)// {// System.out.println("線程名"+threads[i].getName()+"\n");// } //讓新開的新城先執行,控制線程結束 //thread[0]在thread[1]前執行完畢,thread[1]在thread[2]前執行完畢,thread[2]在主線程之前執行完畢 for(int i=n-1;i>0;i--) { try { threads[i].join(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } System.out.println("結束售票\n"); }}
java多線程實現賣票程式