http://wenwen.soso.com/z/q129287952.htm
看一个生产者-消费者问题
class Test
{
public static void main(String[] args)
{
Queue q=new Queue();
Producer p=new Producer(q);
Consumer c=new Consumer(q);
p.start();
c.start();
}
}
class Producer extends Thread
{
Queue q;
Producer(Queue q)
{
this.q=q;
}
public void run()
{
for(int i=0;i<10;i++)
{
q.put(i);
System.out.println("Producer put "+i);
}
}
}
class Consumer extends Thread
{
Queue q;
Consumer(Queue q)
{
this.q=q;
}
public void run()
{
while(true)
{
System.out.println("Consumer get "+q.get());
}
}
}
class Queue
{
int value;
boolean bFull=false;
public synchronized void put(int i)
{
if(!bFull)
{
value=i;
bFull=true;
notify();
}
try
{
wait();
}
catch(Exception e)
{
e.printStackTrace();
}
}
public synchronized int get()
{
if(!bFull)
{
try
{
wait();
}
catch(Exception e)
{
e.printStackTrace();
}
}
bFull=false;
notify();
return value;
}
}
在上述例子中Queue类中的get(int i)和put()方法都是synchronized 修饰的,也就是说在听同一时间只能有一个线程调用 。
main()方法中的p.start();c.start();自动调用Producer 和Consumer 中的run()方法; 当其中一个线程调用wait()时,此线程等待。另外的线程运行,当运行的线程调用notify()时,是处于等待的线程处于准备状态,当cpu分配给资源后,就可以随时运行。