📄 mopersistenceprovider.java
字号:
/*_############################################################################
_##
_## SNMP4J-Agent - MOPersistenceProvider.java
_##
_## Copyright (C) 2005-2008 Frank Fock (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.agent.io;
import java.io.IOException;
/**
* The <code>MOPersistenceProvider</code> interface defines how persistent
* storage can be used to save and restore an agents state. The interface
* intentionally does not define how the persistence provider gets access
* to the agent's state.
*
* @author Frank Fock
* @version 1.2
*/
public interface MOPersistenceProvider {
/**
* Restore (load) agent state from the specified URI (can be as simple as
* a file path).
* @param uri
* a string pointing to the persistent storage from which the agent state
* should be restored from. The format of he string is specified by the
* persistence provider. A <code>null</code> value can be specified to
* let the persistence provider use its default URI. If that default URI
* is <code>null</code> too, a <code>NullPointerException</code> will be
* thrown.
* @param importMode
* specifies how the agent's current state should be update while
* restoring a previous state.
* @throws IOException
* if the restore operation fails.
* @since 1.2
*/
void restore(String uri, int importMode) throws IOException;
/**
* Stores the current agent state to persistent storage specified by the
* supplied URI.
* @param uri
* a string pointing to the persistent storage from which the agent state
* should be restored from. The format of the string is specified by the
* persistence provider. A <code>null</code> value can be specified to
* let the persistence provider use its default URI. If that default URI
* is <code>null</code> too, a <code>NullPointerException</code> will be
* thrown.
* @throws IOException
* if the store operation fails.
* @since 1.2
*/
void store(String uri) throws IOException;
/**
* Checks whether the supplied URI string is valid for this persistence
* provider.
* @param uri
* a string identifying a persistent storage location for this storage
* provider.
* @return
* <code>true</code> if the <code>uri</code> is valid, <code>false</code>
* otherwise.
* @since 1.2
*/
boolean isValidPersistenceURI(String uri);
/**
* Returns an unique ID of the persistence provider which should identify the
* format and type of the persistence provider.
* @return
* an 1-32 character long string that identifies the persistence provider.
* @since 1.2
*/
String getPersistenceProviderID();
/**
* Gets the URI of the default persistent storage for this provider.
* @return
* the URI (e.g. file path) for the default persistent storage location of
* this provider. A provider may use a different one. A <code>null</code>
* value indicates that there is no default location.
*/
String getDefaultURI();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -