/* * Copyright (c) 2003, 2006, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package com.sun.jmx.remote.internal; import java.util.Set; import javax.management.remote.NotificationResult; import javax.management.remote.TargetedNotification; /** A buffer of notifications received from an MBean server. */ public interface NotificationBuffer { /** *

Fetch notifications that match the given listeners.

* *

The operation only considers notifications with a sequence * number at least startSequenceNumber. It will take * no longer than timeout, and will return no more * than maxNotifications different notifications.

* *

If there are no notifications matching the criteria, the * operation will block until one arrives, subject to the * timeout.

* * @param filter an object that will add notifications to a * {@code List} if they match the current * listeners with their filters. * @param startSequenceNumber the first sequence number to * consider. * @param timeout the maximum time to wait. May be 0 to indicate * not to wait if there are no notifications. * @param maxNotifications the maximum number of notifications to * return. May be 0 to indicate a wait for eligible notifications * that will return a usable nextSequenceNumber. The * {@link TargetedNotification} array in the returned {@link * NotificationResult} may contain more than this number of * elements but will not contain more than this number of * different notifications. */ public NotificationResult fetchNotifications(NotificationBufferFilter filter, long startSequenceNumber, long timeout, int maxNotifications) throws InterruptedException; /** *

Discard this buffer.

*/ public void dispose(); }