当前位置:首页 > 开发 > 编程语言 > JDK JVM > 正文

jdk 5.0之后的生产者消费者 改进版

发表于: 2014-08-25   作者:annan211   来源:转载   浏览次数:
摘要: package threadJDK5; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class ThreadTestJDK5 { publ
package threadJDK5;

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

public class ThreadTestJDK5 {
	public static void main(String[] args) {
		Resource r = new Resource();

		Producer p = new Producer(r);
		Consumer c = new Consumer(r);

		Thread t1 = new Thread(p);
		Thread t2 = new Thread(c);

		t1.start();
		t2.start();
	}
}

class Resource{
	private String name;
	private int num;
	private boolean flag;
	private Lock lock = new ReentrantLock();
	// 生产者锁
	private Condition condition_pro = lock.newCondition();
	//消费者锁
	private Condition condition_con = lock.newCondition();
	public void set(Resource r) throws InterruptedException{
		lock.lock();
		if(!r.flag){
			if(num % 2 == 0){
				this.name = "张三------" + num++;
			}else{
				this.name = "丽丽------" + num++;
			}
			System.out.println("生产..."+this.name);
			r.flag = true;
			condition_con.signal();
		}else{
			try {
				condition_pro.await();
			}  finally{
				lock.unlock();
			}
		}
	}

	public void out(Resource r) throws InterruptedException{
		lock.lock();
		if(r.flag){
			System.out.println("消费..."+r.name);
			r.flag = false;
			condition_pro.signal();
		}else{
			try {
				condition_con.await();
			} finally{
				lock.unlock();
			}
		}
	}
}

class Producer implements Runnable{
	private Resource r;
	public Producer(Resource r){
		this.r = r;
	}
	public void run(){
		while(true){
			try {
				r.set(r);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
	}
}

class Consumer implements Runnable{
	private Resource r;
	public Consumer(Resource r){
		this.r = r;
	}
	public void run(){
		while(true){
			try {
				r.out(r);
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
	}
}

jdk 5.0之后的生产者消费者 改进版

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
对于同步代码块,对于锁的操作是隐式的 但是在JDK1.5之前的这种方法效率有点低,判断会很多,后面升
问题描述:有一群生产者进程在不断生产产品,而另一群消费者进程在不断消费生产出的产品;为了了解
生产者消费者问题是一个著名的线程同步问题,该问题描述如下:有一个生产者在生产产品,这些产品将
wait()和notify()¬ifyAll()必须工作在加锁(synchronized)的代码块中。 抢占的锁和释放的锁要是
生产者消费者问题是一个著名的线程同步问题,该问题描述如下:有一个生产者在生产产品,这些产品将
架构设计:生产者/消费者模式 http://www.sina.com.cn 2009年07月30日 00:49 IT168.com 文本Tag:
java线程的生命周期 /** * 公共资源类 */ public class PublicResource { private int number = 0;
在并发编程中使用生产者和消费者模式能够解决绝大多数并发问题。该模式通过平衡生产线程和消费线程
背景知识: 从JDK5开始提供名为Annotation(注释)的功能,它被定义为JSR-175规范。注释是以“@注释
JDK 5.0 新特性: 1. 静态导入 静态导入语法用于导入指定类的某个静态属性值(方法)或全部静态属性值
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号