/*
生产者,消费者。
多生产者,多消费者的问题。
if判断标记,只有一次,会导致不该运行的线程运行了。出现了数据错误的情况。
while判断标记,解决了线程获取执行权后,是否要运行!
notify:只能唤醒一个线程,如果本方唤醒了本方,没有意义。而且while判断标记+notify会导致死锁。
notifyAll解决了本方线程一定会唤醒对方线程的问题。
*/
class Resource
{
	private String name
;
	private int count 
= 1
;
	private boolean flag 
= false;
	public synchronized void set
(String name
)//  
	
{
		while
(flag
)
			try
{this.wait
();}catch
(InterruptedException e
){}//   t1    t0
		
		this.name 
= name + count
;//烤鸭1  烤鸭2  烤鸭3
		count++
;//2 3 4
		System.out.println
(Thread.currentThread
().getName
()+
"...生产者..."+this.name
);//生产烤鸭1 生产烤鸭2 生产烤鸭3
		flag 
= true;
		notifyAll
();
	}
	public synchronized void out
()//  t3
	
{
		while
(!flag
)
			try
{this.wait
();}catch
(InterruptedException e
){}	//t2  t3
		System.out.println
(Thread.currentThread
().getName
()+
"...消费者........"+this.name
);//消费烤鸭1
		flag 
= false;
		notifyAll
();
	}
}
class Producer implements Runnable
{
	private Resource r
;
	Producer
(Resource r
)
	{
		this.r 
= r
;
	}
	public void run
()
	{
		while
(true
)
		{
			r.set
("烤鸭");
		}
	}
}
class Consumer implements Runnable
{
	private Resource r
;
	Consumer
(Resource r
)
	{
		this.r 
= r
;
	}
	public void run
()
	{
		while
(true
)
		{
			r.out
();
		}
	}
}
class  ProducerConsumerDemo
{
	public static void main
(String
[] args
) 
	{
		Resource r 
= new Resource
();
		Producer pro 
= new Producer
(r
);
		Consumer con 
= new Consumer
(r
);
		Thread t0 
= new Thread
(pro
);
		Thread t1 
= new Thread
(pro
);
		Thread t2 
= new Thread
(con
);
		Thread t3 
= new Thread
(con
);
		t0.start
();
		t1.start
();
		t2.start
();
		t3.start
();
	}
}