为了账号安全,请及时绑定邮箱和手机立即绑定

在队列中添加元素时调用侦听器以通知队列元素是可变的

在队列中添加元素时调用侦听器以通知队列元素是可变的

烙印99 2022-12-21 10:11:19
我想每当我们在队列中添加元素时,我应该调用一个方法来在队列中添加元素后立即获取。package com.java.listner;import java.util.LinkedList;import java.util.Queue;public class QueueListner {public static Queue<String> queue=new LinkedList<String>();    public boolean add(String e) {        itemAvailableInqueue();        return false;    }    public static void main(String[] args) {        queue.add("record1");        System.out.println(queue.poll());    }    public void itemAvailableInqueue() {        int size = queue.size();        for (int i = 1; i < size; i++) {            System.out.println(queue.poll());        }    }}
查看完整描述

1 回答

?
繁星coding

TA贡献1797条经验 获得超4个赞

要将监听器添加到队列中,您需要使其“可监听”,最简单的方法是装饰器模式。此模式的目标是在类中添加特性,同时保留其基本功能。

在 的情况下Queue,您只需扩展一个AbstractQueue类,覆盖它的offer方法。其他方法只是委托给后备队列,因为它们不需要通知侦听器。

public class ListenableQueue<E> extends AbstractQueue<E> {


    interface Listener<E> {

        void onElementAdded(E element);

    }


    private final Queue<E> delegate;  // backing queue

    private final List<Listener<E>> listeners = new ArrayList<>();


    public ListenableQueue(Queue<E> delegate) {

        this.delegate = delegate;

    }


    public ListenableQueue<E> registerListener(Listener<E> listener) {

        listeners.add(listener);

        return this;

    }



    @Override

    public boolean offer(E e) {

        // here, we put an element in the backing queue, 

        // then notify listeners

        if (delegate.offer(e)) {

            listeners.forEach(listener -> listener.onElementAdded(e));

            return true;

        } else {

            return false;

        }

    }


    // following methods just delegate to backing instance

    @Override public E poll() { return delegate.poll(); }

    @Override public E peek() { return delegate.peek(); }

    @Override public int size() { return delegate.size(); }

    @Override public Iterator<E> iterator() { return delegate.iterator(); }


}

因此,此ListenableQueue实现Queue接口具有Queue考虑支持委托队列属性的所有功能(即容量限制、阻塞行为等),因此可以像任何其他Queue.


使用示例:


// we create new `LinkedList` as a backing queue and decorate it

ListenableQueue<String> q = new ListenableQueue<>(new LinkedList<>());


// register a listener which polls a queue and prints an element 

q.registerListener(e -> System.out.println(q.poll()));


// voila!

q.add("record1");


查看完整回答
反对 回复 2022-12-21
  • 1 回答
  • 0 关注
  • 114 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号