import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class LockAndUnlockDemo { public static void main(String[] args) { Clerk2 c=new Clerk2(); Thread t=new Thread(new Producer2(c)); Thread t1=new Thread(new Consumer2(c)); t.start(); t1.start(); } } class Clerk2{ private int product=0;//生產者生產的數量給店員 private Lock lock = new ReentrantLock(); private Condition condition_pro = lock.newCondition(); private Condition condition_con = lock.newCondition(); public void addproduct(){ lock.lock(); try { if(this.product>5){ try { condition_con.await(); } catch (InterruptedException e) { e.printStackTrace(); } }else{ product++; System.out.println("生產了第"+product+"個商品"); condition_con.signal(); } }finally { lock.unlock(); } } public void getproduct(){ lock.lock(); try { if(this.product<=0){ try { condition_con.await(); } catch (InterruptedException e) { e.printStackTrace(); } } else{ System.out.println("消費者買走了第"+product+"個商品"); product--; condition_pro.signal(); } } finally { lock.unlock(); } } } class Producer2 implements Runnable{ private Clerk2 clerk; public Producer2(Clerk2 clerk) { super(); this.clerk = clerk; } public void run() { System.out.println("開始生產商品"); while(true){ try { Thread.sleep((int)(Math.random()*10)*1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } clerk.addproduct(); } } } class Consumer2 implements Runnable{ private Clerk2 clerk; public Consumer2(Clerk2 clerk) { super(); this.clerk = clerk; } public void run() { System.out.println("消費者買走商品"); while(true){ try { Thread.sleep((int)(Math.random()*10)*1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } clerk.getproduct(); } } }
java利用lock和unlock實現消費者與生產者問題(多線程)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.