Package org.moeaframework.core
Interface Stateful
- All Known Subinterfaces:
Algorithm
,EpsilonBoxEvolutionaryAlgorithm
,EvolutionaryAlgorithm
- All Known Implementing Classes:
AbstractAlgorithm
,AbstractEvolutionaryAlgorithm
,AbstractPSOAlgorithm
,AbstractSimulatedAnnealingAlgorithm
,AdaptiveGridArchive
,AdaptiveTimeContinuationExtension
,AGEMOEAII
,AlgorithmWrapper
,AMOSA
,CheckpointExtension
,CMAES
,DBEA
,DifferentialEvolution
,EpsilonBoxDominanceArchive
,EpsilonMOEA
,EpsilonNSGAII
,EpsilonProgressContinuationExtension
,EvolutionStrategy
,Extensions
,FitnessBasedArchive
,GDE3
,GeneticAlgorithm
,IBEA
,InstrumentedAlgorithm
,InstrumentedExtension
,IslandMigrationExtension
,MOEAD
,MSOPS
,MSOPSRankedPopulation
,NondominatedPopulation
,NondominatedSortingPopulation
,NSGAII
,NSGAIII
,OMOPSO
,PAES
,PeriodicExtension
,PESA2
,Population
,RandomSearch
,ReferencePointNondominatedSortingPopulation
,ReferenceVectorGuidedPopulation
,RepeatedSingleObjective
,RuntimeCollectorExtension
,RVEA
,SimulatedAnnealing
,SingleObjectiveEvolutionaryAlgorithm
,SMPSO
,SMSEMOA
,SPEA2
,UNSGAIII
,VEGA
public interface Stateful
Interface for objects that can save and load their state.
This is distinct from Serializable
as state aims to only capture the mutable state of an object,
such as the current NFE and population for an Algorithm
, whereas serialization
stores the entire object graph unless fields are excluded using the transient
keyword. This also allows
loading the state into an existing object, rather than constructing a new, deserialized instance of the object.
Serialization also requires access to a no-arg constructor on the first non-serializable superclass, which is not
always possible when a class has required parameters.
That all being said, serialization is still useful for parallel or distributed computing, where objects need to be serialized to send to a different process or machine.
-
Method Summary
Modifier and TypeMethodDescriptionstatic void
checkTypeSafety
(ObjectInputStream stream, Object object) Validates the type safety information embedded in the object stream.default void
loadState
(ObjectInputStream stream) Loads the state of this object from the stream.default void
saveState
(ObjectOutputStream stream) Writes the state of this object to the stream.static void
writeTypeSafety
(ObjectOutputStream stream, Object object) Writes a field into the object stream that can be validated usingcheckTypeSafety(ObjectInputStream, Object)
.
-
Method Details
-
saveState
Writes the state of this object to the stream. The order that objects are written to the stream is important. We recommend first callingsuper.saveState(stream)
followed by writing each field.- Parameters:
stream
- the stream- Throws:
IOException
- if an I/O error occurred
-
loadState
Loads the state of this object from the stream. The order for reading objects from the stream must match the order they are written to the stream insaveState(ObjectOutputStream)
.- Parameters:
stream
- the stream- Throws:
IOException
- if an I/O error occurredClassNotFoundException
- if the stream referenced a class that is not defined
-
writeTypeSafety
Writes a field into the object stream that can be validated usingcheckTypeSafety(ObjectInputStream, Object)
.- Parameters:
stream
- the streamobject
- the stateful object- Throws:
IOException
- if an I/O error occurred
-
checkTypeSafety
static void checkTypeSafety(ObjectInputStream stream, Object object) throws IOException, ClassNotFoundException Validates the type safety information embedded in the object stream.- Parameters:
stream
- the streamobject
- the stateful object- Throws:
IOException
- if an I/O error occurred or the type safety check failedClassNotFoundException
- if the stream referenced a class that is not defined
-