java多线程--ReentrantLock实现生产者与消费者模式

翻译 2017年03月26日 21:25:07


一.本例实现 :一对一交替打印,

一.生产者逻辑 :每次只允许一个生产者来进行生产操作(生产者之间互斥访问仓库),必须等消费者取走数据之后,才能进行下一次的生产

二.消费者逻辑 :每次只允许一个消费者来进行生产操作(消费者之间互斥访问仓库),必须等生产者生产数据之后,才能进行下一次的消费。


二.仓库类:

package lock.produce.comsumer;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;

public class MyService {
	
	private ReentrantLock lock = new ReentrantLock();
	
	private Condition condition = lock.newCondition();
	
	private boolean hasValue = false;
	
	
	/**
	 * 生产数据
	 */
	public void set(){
		
		try {
			lock.lock();      //获取监视器对象,即获取锁
			
			while(hasValue){
				condition.await();
			}
			
			System.out.println("打印*");
			hasValue = true;		//只允许当前一个线程进来,且是消费线程进来
			condition.signal();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			lock.unlock();
		}
	}
	
	
	/**
	 * 消费数据
	 */
	public void get(){
		try {
			lock.lock();      //获取监视器对象,即获取锁
			
			while(!hasValue){
				condition.await();
			}
			
			System.out.println("打印&");
			hasValue = false;		//只允许当前一个线程进来,且是生产者线程进来
			condition.signal();
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			lock.unlock();
		}
	}

}


三.生产者:

package lock.produce.comsumer;


/**
 * 生产者线程
 * @author Administrator
 *
 */
public class MyThreadA extends Thread{
	
	private MyService myService;
	
	public MyThreadA(MyService myService){
		this.myService = myService;
	}
	
	public void run(){
		
		for(int i=0;i<5;i++){
			myService.set();
		}
	}

}


四.消费者类:

package lock.produce.comsumer;

public class MyThreadB extends Thread{

/**
 * 消费者线程
 */
private MyService myService;
	
	public MyThreadB(MyService myService){
		this.myService = myService;
	}
	
	public void run(){
		
		for(int i=0;i<5;i++){
			myService.get();
		}
	}

}


五。测试类:

package lock.produce.comsumer;

public class Main {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		MyService myService = new MyService();
		
		MyThreadA a = new MyThreadA(myService);
		a.start();
		
		
		MyThreadB b = new MyThreadB(myService);
		b.start();
		
	}

}



六。测试结果:

打印*
打印&
打印*
打印&
打印*
打印&
打印*
打印&
打印*
打印&





相关文章推荐

Java多线程实现生产者消费者模式

用java实现生产者消费者模式,在全部代码之后会对重点、难点一一讲解! 以下是全部代码:class Demo7 { public static void main(String[] args...

JAVA多线程(三)生产者消费者模式及实现方法

介绍了生产者消费者模式以及实现方法(wait&notify,阻塞队列

Java多线程通信-利用传统的线程通信wait(),notify()方法实现“生产者消费者模式”

想利用传统的线程通信wait(),notify(),notifyAll()方法,必须依赖于同步监听器的存在,也就是说,对于synchronized修饰的同步方法,因为该类的默认实例(this)就是同步...

java多线程中的生产者消费者模式实现线程间的通信

1.生产者类: package p_t_test; /** * wait/notify变形模式:生产者消费者模式实现进程间通信 * * 生产者 * @author lxb * */ p...

JAVA多线程(五)用lock、synchronized、阻塞队列三种方法实现生产者消费者模式

用乐观锁、悲观锁、阻塞队列三种方法实现生产者消费者模式

Java多线程实现消费者/生产者模式

该程序多线程基础知识学习的。 实现了1个生产者,1个消费者。当生产者一旦生产了task时,通知消费者(当没有task时,消费者是wait状态),消费立即获取它。 用到的知识点: 1、多线程 2...

Java多线程 生产者消费者模式

/** * 公共的资源(多个线程操作的对象) */ public class Info { private boolean b = false; private String name = ...

java多线程(2):线程通信之生产者消费者模式及等待唤醒机制

前言前面的例子都是多个线程在做相同的操作,比如4个线程都对共享数据做tickets–操作。大多情况下,程序中需要不同的线程做不同的事,比如一个线程对共享变量做tickets++操作,另一个线程对共享变...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)