标签:Thread 生产者 lock void ReentrantLock number 遥控器 new public
import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * 生产者消费者模式(传统版) * 一个初始值为0的变量,俩个线程d对其交替操作,一个加1一个减1 循环5次 * * 1 线程 操作 资源类 * 2 判断 干活 通知 * 3 防止虚假唤醒机制 : 多线程的判断用while, if会有虚假唤醒,如果很多线程同时强资源,就可能出现-1/-2的结果。 */ public class ProdConsumerTraditionDemo { public static void main(String[] args) { final ShareData shareData = new ShareData(); Thread thread = new Thread(new Runnable() { @Override public void run() { try { for (int i = 0; i < 6; i++) { shareData.increment(); } } catch (InterruptedException e) { e.printStackTrace(); } } }); thread.setName("a"); thread.start(); final Thread thread1 = new Thread(new Runnable() { @Override public void run() { try { for (int i = 0; i < 6; i++) { shareData.decrement(); } } catch (InterruptedException e) { e.printStackTrace(); } } }); thread1.setName("B"); thread1.start(); } } class ShareData{ private int number = 0; private Lock lock = new ReentrantLock(); Condition condition = lock.newCondition(); //+ public void increment() throws InterruptedException { try { lock.lock(); //1 判断 while (number!=0){ //等待消费 condition.await(); } //2 干活 number ++; System.out.println(Thread.currentThread().getName() + " " + number); //3 通知唤醒 condition.signalAll(); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock(); } } //- public void decrement() throws InterruptedException { try { lock.lock(); //1 判断 while (number==0){ //等待生产 condition.await(); } //2 消费 number --; System.out.println(Thread.currentThread().getName() + " " + number); //3 通知唤醒 condition.signalAll(); } catch (Exception e) { e.printStackTrace(); } finally { lock.unlock(); } } }
标签:Thread,生产者,lock,void,ReentrantLock,number,遥控器,new,public 来源: https://blog.csdn.net/alenejinping/article/details/113742595
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。