📄 transportmapping.java.svn-base
字号:
/*_############################################################################ _## _## SNMP4J - TransportMapping.java _## _## Copyright 2003-2006 Frank Fock and Jochen Katz (SNMP4J.org) _## _## Licensed under the Apache License, Version 2.0 (the "License"); _## you may not use this file except in compliance with the License. _## You may obtain a copy of the License at _## _## http://www.apache.org/licenses/LICENSE-2.0 _## _## Unless required by applicable law or agreed to in writing, software _## distributed under the License is distributed on an "AS IS" BASIS, _## WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. _## See the License for the specific language governing permissions and _## limitations under the License. _## _##########################################################################*/package org.snmp4j;import java.io.IOException;import org.snmp4j.smi.Address;import org.snmp4j.transport.TransportListener;/** * The <code>TransportMapping</code> defines the common interface for SNMP * transport mappings. A transport mapping can only support a single * transport protocol. * * @author Frank Fock * @version 1.6 */public interface TransportMapping { /** * Gets the <code>Address</code> class that is this transport mapping * supports. * @return * a subclass of {@link Address}. */ Class getSupportedAddressClass(); /** * Returns the address that represents the incoming address this transport * mapping uses to listen for incoming packets. * * @return * the address for incoming packets or <code>null</code> this transport * mapping is not configured to listen for incoming packets. * @since 1.6 */ Address getListenAddress(); /** * Sends a message to the supplied address using this transport. * @param address * an <code>Address</code> instance denoting the target address. * @param message * the whole message as an array of bytes. * @throws IOException */ void sendMessage(Address address, byte[] message) throws IOException; /** * Adds a message dispatcher to the transport. Normally, at least one * message dispatcher needs to be added to process responses (or requests). * @param dispatcher * a MessageDispatcher instance. * @see MessageDispatcherImpl * @deprecated * Use {@link #addTransportListener} instead. This method has * been deprecated because the direct coupling between MessageDispatcher * and TransportMappings is not flexible enough and prevents reusing * TransportMappings for other purposes. This method will be removed * with SNMP4J 2.0. */ void addMessageDispatcher(MessageDispatcher dispatcher); /** * Removes a message dispatcher. Incoming messages will no longer be * propagated to the supplied message dispatcher. * @param dispatcher * a previously added MessageDispatcher instance. * @see #addMessageDispatcher * @deprecated * Use {@link #removeTransportListener} instead. */ void removeMessageDispatcher(MessageDispatcher dispatcher); /** * Adds a transport listener to the transport. Normally, at least one * transport listener needs to be added to process incoming messages. * @param transportListener * a <code>TransportListener</code> instance. * @since 1.6 */ void addTransportListener(TransportListener transportListener); /** * Removes a transport listener. Incoming messages will no longer be * propagated to the supplied <code>TransportListener</code>. * @param transportListener * a <code>TransportListener</code> instance. * @since 1.6 */ void removeTransportListener(TransportListener transportListener); /** * Closes the transport an releases all bound resources synchronously. * @throws IOException */ void close() throws IOException; /** * Listen for incoming messages. For connection oriented transports, this * method needs to be called before {@link #sendMessage} is called for the * first time. * @throws IOException */ void listen() throws IOException; /** * Returns <code>true</code> if the transport mapping is listening for * incoming messages. For connection oriented transport mappings this * is a prerequisite to be able to send SNMP messages. For connectionless * transport mappings it is a prerequisite to be able to receive responses. * @return * <code>true</code> if this transport mapping is listening for messages. * @since 1.1 */ boolean isListening(); /** * Gets the maximum length of an incoming message that can be successfully * processed by this transport mapping implementation. * @return * an integer > 484. */ int getMaxInboundMessageSize();}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -