多线程-生产者消费者lock锁
来源:互联网 发布:淘宝双十一c店报名条件 编辑:程序博客网 时间:2024/06/05 09:13
package com.hui.生产消费;import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;public class indexLock { public static void main(String[] args) { Pack p = new Pack(); producer producer = new producer(p); Consumer consumer = new Consumer(p); Thread thread = new Thread(producer,"生产者1"); Thread thread2 = new Thread(producer,"生产者2"); Thread thread3 = new Thread(consumer,"消费者1"); Thread thread4 = new Thread(consumer,"消费者2"); thread.start(); thread2.start(); thread3.start(); thread4.start(); }}//面包class bread{ private int id; public bread(int id) { this.id = id; } public String toString() { return "id = "+id; }}/** * Lock 实现提供了比使用 synchronized 方法和语句可获得的更广泛的锁定操作。 * 此实现允许更灵活的结构,可以具有差别很大的属性,可以支持多个相关的 Condition 对象。 * Condition 将 Object 监视器方法(wait、notify 和 notifyAll)分解成截然不同的对象, * 以便通过将这些对象与任意 Lock 实现组合使用,为每个对象提供多个等待 set(wait-set)。 * 其中,Lock 替代了 synchronized 方法和语句的使用,Condition 替代了 Object 监视器方法的使用。 * @author Hui */class Pack{ private bread []arr = new bread[10]; private int count = 0; private boolean Empty = true; private Lock lock = new ReentrantLock(); //同步锁 private Condition con_pro = lock.newCondition(); //生产者监视器 private Condition con_cus = lock.newCondition(); // 消费者监视器 /** * 放入面包 * @throws InterruptedException */ public void Input() throws InterruptedException { lock.lock(); try { //这里的try{}finally{} 写法 while(!Empty){ //为空判断 System.out.println(Thread.currentThread().getName()+"正在等待"); con_pro.await(); //生产者等待 } arr[count] = new bread(count+1); count++; System.out.println(Thread.currentThread().getName()+"正在生产第"+count+"个面包"+arr[count-1]); if(count == arr.length){ Empty = false; con_cus.signalAll(); //唤醒消费者所有线程,否者每次只唤醒首先等待的消费者 } } finally { lock.unlock(); } } /** * 取面包 * @throws InterruptedException */ public void Output() throws InterruptedException{ lock.lock(); try { //这里的try{}finally{} 写法 while(Empty){ //为空判断 System.out.println(Thread.currentThread().getName()+"---正在等待"); con_cus.await(); //消费者等待 } System.out.println(Thread.currentThread().getName()+"---正在消费第"+(11-count)+"个面包"+arr[count-1]); count--; if(count == 0){ Empty = true; con_pro.signalAll(); //唤醒生产者所有线程, } } finally { lock.unlock(); } }}/** * 生产者 * @author Hui */class producer implements Runnable{ private Pack pack = null; private boolean go_on = true; public producer(Pack p) { //传入单个共享资源对象 this.pack = p; } public void run(){ while(go_on){ try { pack.Input(); Thread.sleep(20); } catch (InterruptedException e) { e.printStackTrace(); } } }}/** * 消费者 * @author Hui */class Consumer implements Runnable{ private Pack pack = null; private boolean go_on = true; public Consumer(Pack p) { //传入单个共享资源对象 this.pack = p; } public void run(){ while(go_on){ try { pack.Output(); Thread.sleep(20); } catch (InterruptedException e) { e.printStackTrace(); } } }}
阅读全文
2 0
- 多线程-生产者消费者lock锁
- 多线程生产者消费者Demo2_ Lock操作
- Lock锁 实现生产者和消费者问题
- Java多线程-Lock锁的使用,以及生产者和消费者的实现
- 多线程——用Lock(锁)和Condition(监听器)来优化生产者消费者模式
- 生产者和消费者 用Lock控制多线程共享资源
- Lock 生产者消费者模型示例
- Java 多线程 (PART XVIII) Lock(II)用lock实现生产者消费者模式
- java多线程 消费者-生产者
- 生产者消费者问题--多线程
- 多线程之生产者-消费者
- java多线程 消费者-生产者
- java 多线程 生产者消费者
- JAVA [ 多线程 -- 生产者消费者 ]
- 多线程--生产者消费者问题
- 生产者-消费者多线程实现
- 多线程练习----生产者消费者
- 多线程生产者和消费者
- 2017年小红书在线笔试编程第二题
- Netty源码分析:ChannelPipeline
- hdu 2094 谁是冠军(STL,拓扑排序)
- 【bzoj1370】【团伙】原来并查集还能这么用?!
- Linux 基础知识(1)—学习路线
- 多线程-生产者消费者lock锁
- solr服务快速搭建、配置中文分词、数据导入即solrj增删改查
- jquery().offset()、e.offsetX、e.clientX
- codeforces 864C
- JavaScript --02 语法
- CSS3 三维立体文字及旋转特效
- codeforces 864D
- poj3667 Hotel (线段树+区间合并)
- jsonp 的原理与实现