JAVA 生产者与消费者

生产者与消费者 满足

  • 自定义同步容器,容器容量上限为10。可以在多线程中应用,并保证数据线程安全。
1,wait()和notifyAll()
public class Test<E> {
        private final LinkedList<E> list = new LinkedList<E>();
        private final int MAX = 10;
        private int count = 0;
        
        public synchronized int getCount() {
            return count;
        }
        
        public synchronized void put(E e) {
            // wait/notify都是和while配合应用的。可以避免多线程并发判断逻辑失效问题。
            while (list.size()==MAX) {
                try {
                    this.wait();
                } catch (InterruptedException e1) {
                    e1.printStackTrace();
                }
            }
            list.add(e);
            count++;
            this.notifyAll();
        }
        
        public synchronized E get() {
            E e = null;
            // wait/notify都是和while配合应用的。可以避免多线程并发判断逻辑失效问题。
            while(list.size()==0) {
                try {
                    this.wait();
                } catch (InterruptedException ee) {
                    ee.printStackTrace();
                }
            }
            e =list.removeFirst();
            count--;
            this.notifyAll();
            return e;
        }
        
}

2, 使用ReentrantLock 的Condition

public class Test<E> {
    private final LinkedList<E> list = new LinkedList<E>();
    private final int MAX = 10 ;
    private int count = 0;
    
    private Lock lock = new ReentrantLock();        
    private Condition producer = lock.newCondition();
    private Condition consumer = lock.newCondition();
    
    public int getCount() {
        return count;
    }
    
    public synchronized void put(E e) {
        lock.lock();
        try {
            while(list.size()==MAX) {
                System.out.println("等待...");
                try {
                    // 借助条件,进入的等待队列。
                    producer.await();
                } catch (InterruptedException e1) {
                    // TODO Auto-generated catch block
                }
            }
            list.add(e);
            count++;
            // 借助条件,唤醒所有的消费者。
            consumer.signal();
        } catch (Exception e2) {
            e2.printStackTrace();
        }finally {
            lock.unlock();  
        }
    }
    
    public synchronized E get() {
        lock.lock();
        E e = null;
        try {
            while (list.size()==0) {
                try {
                    // 借助条件,消费者进入等待队列
                    consumer.wait();
                } catch (InterruptedException e1) {
                    e1.printStackTrace();
                }
            }
            e = list.removeFirst();
            count--;
            // 借助条件,唤醒所有的生产者
            producer.signal();
        } catch (Exception e2) {
            e2.printStackTrace();
        }finally {
            lock.unlock();
        }
        return e;
    }
        
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Java SE 基础: 封装、继承、多态 封装: 概念:就是把对象的属性和操作(或服务)结合为一个独立的整体,并尽...
    Jayden_Cao阅读 2,140评论 0 8
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,765评论 18 399
  • 自从老师带我们去看魏一言姐姐演讲时,我的感触很大,我非常想像魏一言姐姐那样,我仔细的看她的计划表,哇好厉...
    哈佛女孩阅读 329评论 1 2
  • 生气没有一点用,对自己好点。 你会因为鸡毛蒜皮的小事生气,生气之后开始闷自己,闷来闷去还是自己难受,事情过去以后觉...
    猫是他的阅读 177评论 0 0
  • 国庆假期要来了,睡在床上辗转反侧,身边的好朋友们都计划出游,而自己的男朋友要回家,自己的爸爸已经这一个月就给自己打...
    萳柯_阅读 121评论 0 0