package org.bouncycastle.util;

Interface for Memoable objects. Memoable objects allow the taking of a snapshot of their internal state via the copy() method and then reseting the object back to that state later using the reset() method.
/** * Interface for Memoable objects. Memoable objects allow the taking of a snapshot of their internal state * via the copy() method and then reseting the object back to that state later using the reset() method. */
public interface Memoable {
Produce a copy of this object with its configuration and in its current state.

The returned object may be used simply to store the state, or may be used as a similar object starting from the copied state.

/** * Produce a copy of this object with its configuration and in its current state. * <p> * The returned object may be used simply to store the state, or may be used as a similar object * starting from the copied state. */
Memoable copy();
Restore a copied object state into this object.

Implementations of this method should try to avoid or minimise memory allocation to perform the reset.

Params:
  • other – an object originally copied from an object of the same type as this instance.
Throws:
/** * Restore a copied object state into this object. * <p> * Implementations of this method <em>should</em> try to avoid or minimise memory allocation to perform the reset. * * @param other an object originally {@link #copy() copied} from an object of the same type as this instance. * @throws ClassCastException if the provided object is not of the correct type. * @throws MemoableResetException if the <b>other</b> parameter is in some other way invalid. */
void reset(Memoable other); }