多线程——等待唤醒机制经典实例:生产者消费者模式(优化)

package com.work.wor01;
/**
 * 等待唤醒机制经典实例:生产者消费者模式。
 * 
 * 当使用多个生成者线程,多个消费者线程时,会出现线程不安全的现象,即使是同步了,也不管用。
 * 
 * 发生的问题:
 * 生产者生产的商品没有被消费,就生成了新的商品。
 * 
 * 线程不安全现象产生的原因:
		1.本方唤醒了本方
		2.被唤醒的本方没有判断标记。
	解决结论:
		无论哪个线程被唤醒,都一定要判断标记。
	解决方案:
		把if改成while即可。
	出现了新的问题,所有的线程都在等待,程序死锁了,怎么办?
	分析:本方唤醒了本方,没有唤醒对方。
	解决方案:
	一定要唤醒对象,没有直接唤醒对方的方法,所以唤醒所有线程。
 * */
//资源类
class Resource1{
	private String name;
	private int count = 1;
	boolean flag;
	
	public synchronized void set(String name){
		while(flag){
			try {
				this.wait();
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
		this.name = name+count;
		count++;
		System.out.println(Thread.currentThread().getName()+"..生产了.."+this.name);
		flag=true;
		this.notifyAll();
	}
	
	public synchronized void get(){
		while(!flag){
			try {
				this.wait();
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}	
		}
		System.out.println(Thread.currentThread().getName()+"..消费了.."+this.name);
		flag = false;
		this.notifyAll();
	}
}
//生产类
class Produce implements Runnable{
	Resource1 r;
	
	public Produce(Resource1 r) {
		super();
		this.r = r;
	}

	@Override
	public void run() {
		while(true){
			r.set("馒头");
		}
	}
}

//消费类
class Customer1 implements Runnable{
	Resource1 r;
	
	public Customer1(Resource1 r) {
		super();
		this.r = r;
	}

	@Override
	public void run() {
		while(true){
			r.get();
		}
	}
}

public class ProCuswork01 {
	public static void main(String[] args) {
		Resource1 r = new Resource1();
		
		Produce p = new Produce(r);
		Customer1 c = new Customer1(r);
		
		Thread t1 = new Thread(p);
		Thread t2 = new Thread(c);
		Thread t3 = new Thread(p);
		Thread t4 = new Thread(c);
		t1.start();
		t2.start();
		t3.start();
		t4.start();
	}
	
	
	
	
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值