标签:消费者 Thread 生产者 clerk public 产品 设计模式 Clerk 店员
/**
* 生产者(Productor)将产品交给店员(Clerk),消费者(Customer)从店员取走产品
* 店员只能持有固定的数目产品(例如:20)
* 如果店员的产品满了,会通知生产者停一下。
* 如果店员的产品没了,会通知消费者等一下。
* 是多线程问题,多个消费者,多个生产者,共享数据是产品和店员
*
/** * 店员 */ class Clerk{ // 产品数量 private int productCount = 0; /** * 生产产品 */ public synchronized void produceProduct() { if(productCount<20){ productCount++; System.out.println(Thread.currentThread().getName()+"生产产品,目前产品数:"+productCount); // 生产完就唤醒消费者 notify(); }else{ // 等待 try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } } public synchronized void consumeProduct() { if(productCount>0){ System.out.println(Thread.currentThread().getName()+"消费产品,目前产品号:"+productCount); productCount--; // 消费完就唤醒生产者 notify(); }else{ // 等待 try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } } }
/** *生产者 */ class Producer extends Thread{ private Clerk clerk; public Producer(Clerk clerk) { this.clerk = clerk; } @Override public void run() { System.out.println(getName()+"开始生产产品..."); while(true){ try { Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } clerk.produceProduct(); } } }
/** * 消费者 */ class Consumer extends Thread{ private Clerk clerk; public Consumer(Clerk clerk) { this.clerk = clerk; } @Override public void run() { System.out.println(getName()+"开始消费产品...."); while(true){ try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } clerk.consumeProduct(); } } }
标签:消费者,Thread,生产者,clerk,public,产品,设计模式,Clerk,店员 来源: https://www.cnblogs.com/wsZzz1997/p/14641573.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。