public class SerializationUtils
extends java.lang.Object
Assists with the serialization process and performs additional functionality based on serialization.
This class throws exceptions for invalid null
inputs.
Each method documents its behaviour in more detail.
限定符和类型 | 方法和说明 |
---|---|
static java.lang.Object |
clone(java.io.Serializable object)
Deep clone an
Object using serialization. |
static java.lang.Object |
deserializable(java.io.File cacheFile) |
static java.lang.Object |
deserialize(byte[] objectData)
Deserializes a single
Object from an array of bytes. |
static java.lang.Object |
deserialize(java.io.InputStream inputStream)
Deserializes an
Object from the specified stream. |
static void |
serializable(java.io.Serializable obj,
java.io.File cacheFile) |
static byte[] |
serialize(java.io.Serializable obj)
Serializes an
Object to a byte array for
storage/serialization. |
static void |
serialize(java.io.Serializable obj,
java.io.OutputStream outputStream)
Serializes an
Object to the specified stream. |
public static java.lang.Object clone(java.io.Serializable object)
Deep clone an Object
using serialization.
This is many times slower than writing clone methods by hand
on all objects in your object graph. However, for complex object
graphs, or for those that don't support deep cloning this can
be a simple alternative implementation. Of course all the objects
must be Serializable
.
object
- the Serializable
object to clonepublic static void serialize(java.io.Serializable obj, java.io.OutputStream outputStream)
Serializes an Object
to the specified stream.
The stream will be closed once the object is written. This avoids the need for a finally clause, and maybe also exception handling, in the application code.
The stream passed in is not buffered internally within this method. This is the responsibility of your application if desired.
obj
- the object to serialize to bytes, may be nulloutputStream
- the stream to write to, must not be nulljava.lang.IllegalArgumentException
- if outputStream
is null
public static byte[] serialize(java.io.Serializable obj)
Serializes an Object
to a byte array for
storage/serialization.
obj
- the object to serialize to bytespublic static java.lang.Object deserialize(java.io.InputStream inputStream)
Deserializes an Object
from the specified stream.
The stream will be closed once the object is written. This avoids the need for a finally clause, and maybe also exception handling, in the application code.
The stream passed in is not buffered internally within this method. This is the responsibility of your application if desired.
inputStream
- the serialized object input stream, must not be nulljava.lang.IllegalArgumentException
- if inputStream
is null
public static java.lang.Object deserialize(byte[] objectData)
Deserializes a single Object
from an array of bytes.
objectData
- the serialized object, must not be nulljava.lang.IllegalArgumentException
- if objectData
is null
public static java.lang.Object deserializable(java.io.File cacheFile) throws java.io.IOException, java.lang.ClassNotFoundException
java.io.IOException
java.lang.ClassNotFoundException
public static void serializable(java.io.Serializable obj, java.io.File cacheFile) throws java.io.IOException
java.io.IOException