/* * 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 ListnextSequenceNumber
. 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(); }