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

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

发表于: 2014-08-26   作者:annan211   来源:转载   浏览次数:
摘要: package thread; import java.util.ArrayList; import java.util.List; public class ArrayListTest { public static final int Storge_Size = 100; public static void main(String[] args) { Arra
package thread;

import java.util.ArrayList;
import java.util.List;

public class ArrayListTest {
	public static final int Storge_Size = 100;
	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<Integer>(ArrayListTest.Storge_Size);
	private int num = 1;
	public synchronized void set(ArrayListStorge s){
		while(s.list.size()>=ArrayListTest.Storge_Size){
			try {
				this.wait();
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
		s.list.add(num++);
		System.out.println(Thread.currentThread().getName()+"--存入----"+list.get(s.list.size()-1));
		if(s.list.size()>0){
			this.notifyAll();
		}
	}

	public synchronized void out(ArrayListStorge s){
		while(s.list.size()<=0){
			try {
				this.wait();
			} catch (InterruptedException e) {
				e.printStackTrace();
			}
		}
		System.out.println(Thread.currentThread().getName()+"--取出....."+s.list.remove(s.list.size()-1));
		if(s.list.size()<ArrayListTest.Storge_Size){
			this.notifyAll();
		}
	}
}

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

class M implements Runnable{
	private ArrayListStorge s;
	public M(ArrayListStorge s){
		this.s = s;
	}
	public void run(){
		while(true){
			this.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号