A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 郑元皓 中级黑马   /  2013-3-19 20:02  /  1286 人查看  /  2 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 郑元皓 于 2013-3-19 22:08 编辑

import java.util.concurrent.locks.*;

class ProducerConsumerDemo2
{
        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(pro);
                Thread t3 = new Thread(con);
                Thread t4 = new Thread(con);

                t1.start();
                t2.start();
                t3.start();
                t4.start();

        }
}

class Resource
{
        private String name;
        private int count = 1;
        private boolean flag = false;
                        //  t1    t2
        private Lock lock = new ReentrantLock();

        private Condition condition_pro = lock.newCondition();
        private Condition condition_con = lock.newCondition();



        public  void set(String name)throws InterruptedException
        {
                lock.lock();
                try
                {
                        while(flag)
                                condition_pro.await();//t1,t2
                        this.name = name+"--"+count++;

                        System.out.println(Thread.currentThread().getName()+"...生产者.."+this.name);
                        flag = true;
                        condition_con.signal();
                }
                finally
                {
                        lock.unlock();//释放锁的动作一定要执行。
                }
        }


        //  t3   t4  
        public  void out()throws InterruptedException
        {
                lock.lock();
                try
                {
                        while(!flag)
                                condition_con.await();
                        System.out.println(Thread.currentThread().getName()+"...消费者........."+this.name);
                        flag = false;
                        condition_pro.signal();
                }
                finally
                {
                        lock.unlock();
                }
               
        }
}

class Producer implements Runnable
{
        private Resource res;

        Producer(Resource res)
        {
                this.res = res;
        }
        public void run()
        {
                while(true)
                {
                        try
                        {
                                res.set("+商品+");
                        }
                        catch (InterruptedException e)
                        {
                        }
                        
                }
        }
}

class Consumer implements Runnable
{
        private Resource res;

        Consumer(Resource res)
        {
                this.res = res;
        }
        public void run()
        {
                while(true)
                {
                        try
                        {
                                res.out();
                        }
                        catch (InterruptedException e)
                        {
                        }
                }
        }
}

这里面的private Condition condition_pro = lock.newCondition();
        private Condition condition_con = lock.newCondition();

这两句话我不理解,谁能和我详细解释下。还有
lock.lock();
condition_pro.await();
condition_con.signal();
lock.unlock();
这些是怎么调用的。我实在听毕老师说的犯迷糊了。谁能和我简单说说运行的步骤。如:什么调用什么用什么方法等等这样讲解。谢谢了。

评分

参与人数 1技术分 +1 收起 理由
洪建超 + 1

查看全部评分

2 个回复

倒序浏览
将同步Synchronized替换成现实Lock操作。
将Object中的wait,notify notifyAll,替换了Condition对象。
该对象可以Lock锁 进行获取。
该示例中,实现了本方只唤醒对方操作。

Lock:替代了Synchronized
        lock
        unlock
        newCondition()
你可以查查JDK,看看。

Condition:替代了Object wait notify notifyAll
        await();
        signal();
        signalAll();

private Lock lock=new ReentrantLock();//创建创建所对象。
private Condition condition_pro = lock.newCondition();//调用lock的newCondition方法 获得Condition对象
private Condition condition_con = lock.newCondition();


lock.lock(); //加锁
condition_pro.await();//让生产等待
condition_con.signal();/唤醒消费线程
lock.unlock();// 解锁
实例:
class X {
   private final ReentrantLock lock = new ReentrantLock();
   // ...

   public void m() {
     lock.lock();  // block until condition holds
     try {
       // ... method body
     } finally {
       lock.unlock()
     }
   }
}

评分

参与人数 1技术分 +1 收起 理由
洪建超 + 1

查看全部评分

回复 使用道具 举报
黑马17期-闫东东 发表于 2013-3-19 20:17
将同步Synchronized替换成现实Lock操作。
将Object中的wait,notify notifyAll,替换了Condition对象。
该 ...

谢了。我自己在研究下去
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马