黑马程序员技术交流社区

标题: 昨天在联系多线程通讯的时候出现了下面打印结果!求解释 [打印本页]

作者: uoyouwy    时间: 2014-10-21 06:37
标题: 昨天在联系多线程通讯的时候出现了下面打印结果!求解释
本帖最后由 uoyouwy 于 2014-10-21 21:35 编辑

昨天在练习多线程通讯的时候出现下面问题,求解释,代码如下public class ProducerConsumerDemo {
        public  static  void  main (String [] args){
        Resource  r=new  Resource();
        Producer  pro=new  Producer(r);
        Consumer  con=new Consumer(r);
        Thread  t1=new Thread(pro);
        Thread  t2=new  Thread(con);
        t1.start();
        t2.start();
       
        }

}

class Resource{
        private String name;
        private int  count=1;
        private boolean flag=false;
        public  synchronized void set(String name){
                //while(flag)
                 //如果用IF只会判断等着
                if(flag)   
                        try {wait();}catch(Exception e){}
                this.name=name+"--"+count++;
                System.out.println(Thread.currentThread().getName()+"----生产者---"+this.name);
                flag=true;  //将对方唤醒
                this.notify();       
                //this.notifyAll();
        }
        public  synchronized void Out(){
                if(!flag)
                //while (!flag)
                        try {wait();}catch(Exception e){}
                System.out.println(Thread.currentThread().getName()+"----消*费*者---"+this.name);
                flag=false; //将对方唤醒。
                this.notify();       
                //this.notifyAll();
        }
}

class Producer implements Runnable{
       
        private  Resource  res;
        Producer (Resource  res){
                this.res=res;
        }
        public void run() {
                 while (true){
                         res.set("+商品+");
                 }
               
         }
        }
        class Consumer implements Runnable{
               
                private  Resource  res;
                Consumer (Resource  res){
                        this.res=res;
                }
                public void run() {
                         while (true){
                                 res.Out();
                         }
                       
                }
        }

20141020161708.png (6.77 KB, 下载次数: 21)

20141020161708.png

作者: 淡淡的雨    时间: 2014-10-21 09:32
楼主可以把源码放上,也许大家就能看个清楚了
作者: uoyouwy    时间: 2014-10-21 21:36
淡淡的雨 发表于 2014-10-21 09:32
楼主可以把源码放上,也许大家就能看个清楚了

已经编辑好了,不过这个问题似乎并不是固定的,我运行程序是也就是出现了两次




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2