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

jdk 5.0之后生产者消费者(基于指定大小集合操作)

发表于: 2014-08-26   作者:annan211   来源:转载   浏览次数:
摘要: package threadJDK5; import java.util.ArrayList; import java.util.List; import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.R
package threadJDK5;

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

public class ArrayListTestJDK5 {
	public static final int Sorge_Size = 10;
	public static void main(String[] args) {
		ArrayListStorge storge = new ArrayListStorge();

		P p = new P(storge);
		M m = new M(storge);

		Thread t1 = new Thread(p);
		Thread t2 = new Thread(p);
		Thread t3 = new Thread(p);
		Thread t4 = new Thread(p);

		Thread t5 = new Thread(m);
		Thread t6 = new Thread(m);
		Thread t7 = new Thread(m);
		Thread t8 = new Thread(m);

		t1.start();
		t2.start();
		t3.start();
		t4.start();
		t5.start();
		t6.start();
		t7.start();
		t8.start();
	}
}

class ArrayListStorge{
	private List<Integer> list = new ArrayList(ArrayListTestJDK5.Sorge_Size);
	private int num;
	private Lock lock = new ReentrantLock();
	private Condition condition_p = lock.newCondition();
	private Condition condition_m = lock.newCondition();

	public void set(ArrayListStorge s){
		lock.lock();
		while(list.size()>=ArrayListTestJDK5.Sorge_Size){
			try {
				condition_p.await();
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}

		s.list.add(num++);
		System.out.println(Thread.currentThread().getName()+"...存入----"+s.list.get(s.list.size()-1));
		if(s.list.size()>0){
			condition_m.signal();
			lock.unlock();
		}
	}

	public void out(ArrayListStorge s){
		lock.lock();
		while(s.list.size()<=0){
			try {
				condition_m.await();
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
		System.out.println(Thread.currentThread().getName()+"...取出-----"+s.list.remove(s.list.size()-1));
		if(s.list.size()<=0){
			condition_p.signal();
			lock.unlock();
		}
	}
}

class P implements Runnable{
	private ArrayListStorge s;
	public P(ArrayListStorge s){
		this.s = s;
	}
	public void run(){
		while(true){
			s.set(s);
		}
	}
}

class M implements Runnable{
	private ArrayListStorge s;
	public M(ArrayListStorge s){
		this.s = s;
	}
	public void run(){
		while(true){
			s.out(s);
		}
	}
}

jdk 5.0之后生产者消费者(基于指定大小集合操作)

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
本章目标 加深线程同步操作的理解 了解Object类中对线程的支持方法 实例要求 在线程操作中有一个经
LabVIEW之生产者/消费者模式--队列操作 彭会锋 本文章主要是对学习LabVIEW之生产者/消费者模式的学
对于同步代码块,对于锁的操作是隐式的 但是在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;
在并发编程中使用生产者和消费者模式能够解决绝大多数并发问题。该模式通过平衡生产线程和消费线程
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号