多线程初步与生产者消费者问题

本文通过Java代码实现生产者消费者模式,阐述了当仓库满或空时如何协调生产者与消费者的运行逻辑。通过同步机制保证了线程间的正确交互。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

文中图片、知识点及其代码参考共3个来源:http://www.cnblogs.com/mengdd/archive/2013/02/16/2913649.html

http://blog.youkuaiyun.com/liranke/article/details/12222265

http://www.cnblogs.com/wxd0108/p/5479442.html



如图中,一个线程调用start()之后进入Runnable状态等待JVM调用,JVM调用到则进入Running状态。

Running状态可以用join()或者sleep()进入block(阻塞)状态。

Running时wait()可以进入等待池,此时用notify()可以进入锁定池,等待同步锁释放时在回到Runnable状态等待调用


生产者消费者问题:

当生产者的产品堆满仓库时,需要停止生产并且尽快卖出产品。

当消费者买不到产品时(库存为0),提醒生产者继续生产。

package junitTest;

import java.util.ArrayList;

public class PCTest {

	
	static ArrayList<Object> arrayList = new ArrayList<>();
	
	public static final int MAX = 5;
	int sum1=20;
	int sum2=20;
	
	class Producer extends Thread{
		@Override
		public void run() {
			
			while(true){
				synchronized (arrayList) {
					if(arrayList.size()>=MAX){
						System.out.println("产品已满");
						try {
							arrayList.wait();
						} catch (InterruptedException e) {
							// TODO Auto-generated catch block
							e.printStackTrace();
						}
						
						
					}
					Object object = new Object();
					arrayList.add(object);
					System.out.println("加入第"+arrayList.size()+"个产品");
					try {
						Thread.sleep((long) (Math.random() * 3000));
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					arrayList.notify();
				}
			}
		}
}
	
	class Consumer extends Thread{
		@Override
		public void run() {
			
			while(true){
				synchronized (arrayList) {
					if(arrayList.size()==0){
						try{
							System.out.println("产品已空");
							arrayList.wait();
						}catch (InterruptedException e) {
							// TODO: handle exception
							e.printStackTrace();
						}
					}
					arrayList.remove(arrayList.size()-1);
					System.out.println("移除第"+arrayList.size()+"个产品");
					try {
						Thread.sleep((long) (Math.random() * 3000));
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					arrayList.notify();
				}
			}
		}
	}
	
	public void begin(){
		new Producer().start();
		new Consumer().start();
	}
	
	public static void main(String[] args) {
		PCTest pcTest = new PCTest();
		arrayList.clear();
		pcTest.begin();
	}

	
}

有错误请指出,谢谢。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值