Table of Contents
1 Serialization" >1 Serialization
1. What is serialization? " >1. What is serialization?
2. The role of serialization " > 2. The role of serialization
3. Conditions for serialization " > 3. Conditions for serialization
Home Java javaTutorial What is serialization? A detailed introduction to serialization

What is serialization? A detailed introduction to serialization

Jun 20, 2017 pm 02:25 PM
Serialization

1 Serialization

1. What is serialization?

Writing objects in memory to the hard disk is serialization, which is no different from general output, except that the output data is an object, not ordinary text.

2. The role of serialization

Because the storage of data in memory is temporary, if you need to save the object for a long time, you must Writing to the hard disk results in serialization.

3. Conditions for serialization

# For an object to be serialized, the class to which the object belongs must implement the Serializable interface. This interface It is an iconic interface without any fields or abstract methods. When the JVM encounters this interface, it will assign a serialized version number to the class.

4. When an object is serialized, the global variables in the object including private type variables will be written to the hard disk.

5. Fields that cannot be serialized:

  1. Static fields cannot be serialized, the value of a static variable It is the value in the current JVM, not the value set during serialization.

  2. #Fields modified by transient cannot be serialized.

6. Serialization operation:

OutputStream ops=new FileOuptStream(path);
ObjectOuptStream oos=new ObjectOutputStream(ops);
Object obj=new Ojbect();
oos.writeObject(obj);
Copy after login

2 Deserialization

1. What is deserialization

Deserialization is to write the data in the hard disk into the memory and obtain the data stored in object in the file.

2. Deserialization operation requirements

The order of deserialization must be consistent with the order of serialization.

3. Serialization version number

⑴ During serialization, a long number will be generated, called the serialization version number, and saved at the same time In the serialized file and the class file, compare the two

numbers during deserialization. If they are the same, the serialization is successful; if they are not the same, the deserialization cannot be performed.

⑵ The serialized version number is used to mark the version of the entity class. Once the entity class is

modified, if the serialized version number is not explicitly specified, the system will automatically generate it A new version number. If the two version numbers are different, they cannot be serialized. Generally, the serialization version number is explicitly set in the entity class that needs to be serialized.

⑶ Recompiling does not necessarily generate a new serialized version number. Only when the entity class changes will a new serialized version number be generated.

⑷Parsing process

# When deserializing, first compare the serialized version number in the serialized file and the class file to see if they are the same. If they are the same , indicating that the serialized file is generated by the current

class file and can be deserialized; not the same, indicating that it is not generated by the current class file, the version is inconsistent, and cannot be deserialized.

⑸Desequence operation:

InputStream is=new FileInputStream(path);
ObjectInputStream ois=new ObjectIputStream(is);
Object obj=ois.readObject();
Copy after login

The above is the detailed content of What is serialization? A detailed introduction to serialization. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

In Java, how can we serialize a list of objects using flexjson? In Java, how can we serialize a list of objects using flexjson? Sep 05, 2023 pm 11:09 PM

Flexjson is a lightweight library for serializing and deserializing Java objects to and from JSON format. We can serialize a list of objects using the serialize() method of the JSONSerializer class. This method performs shallow serialization on the target instance. We need to pass a list of objects of list type as a parameter to the serialize() method. Syntax publicStringserialize(Objecttarget) example importflexjson.JSONSerializer;importjava.util.*;publicclassJsonSerial

How does Java serialization affect performance? How does Java serialization affect performance? Apr 16, 2024 pm 06:36 PM

The impact of serialization on Java performance: The serialization process relies on reflection, which will significantly affect performance. Serialization requires the creation of a byte stream to store object data, resulting in memory allocation and processing costs. Serializing large objects consumes a lot of memory and time. Serialized objects increase load when transmitted over the network.

How does the C++ function library perform serialization and deserialization? How does the C++ function library perform serialization and deserialization? Apr 18, 2024 am 10:06 AM

C++ Library Serialization and Deserialization Guide Serialization: Creating an output stream and converting it to an archive format. Serialize objects into archive. Deserialization: Creates an input stream and restores it from archive format. Deserialize objects from the archive. Practical example: Serialization: Creating an output stream. Create an archive object. Create and serialize objects into the archive. Deserialization: Create an input stream. Create an archive object. Create objects and deserialize them from the archive.

PHP data processing skills: How to use the serialize and unserialize functions to implement data serialization and deserialization PHP data processing skills: How to use the serialize and unserialize functions to implement data serialization and deserialization Jul 29, 2023 am 10:49 AM

PHP data processing skills: How to use the serialize and unserialize functions to implement data serialization and deserialization Serialization and deserialization are one of the commonly used data processing skills in computer science. In PHP, we can use the serialize() and unserialize() functions to implement data serialization and deserialization operations. This article will give you a detailed introduction to how to use these two functions and provide relevant code examples. 1. What is serialization and deserialization in computer programming?

How to serialize the order of properties using Jackson library in Java? How to serialize the order of properties using Jackson library in Java? Aug 28, 2023 pm 12:45 PM

@JsonPropertyOrder is an annotation used at class level. It takes as an attribute a list of fields that defines the order in which the fields appear in the string generated by the JSON serialization of the object. Properties included in the annotation declaration can be serialized first (in the order they are defined), followed by any properties not included in the definition. Syntax public@interfaceJsonPropertyOrder Example importcom.fasterxml.jackson.core.*;importcom.fasterxml.jackson.databind.*;importcom.fasterxml.jac

How to serialize a map using the flexjson library in Java? How to serialize a map using the flexjson library in Java? Aug 26, 2023 pm 08:13 PM

Flexjson is a lightweight library for serializing and deserializing Java objects to and from JSON format. We can also serialize a Map using the serialize() method of the JSONSerializer class, which performs shallow serialization on the target instance. Syntax publicStringserialize(Objecttarget) example importflexjson.JSONSerializer;importjava.util.*;publicclassJsonSerializeMapTest{ publ

Serialization and deserialization of interfaces and abstract classes in Java Serialization and deserialization of interfaces and abstract classes in Java May 02, 2024 am 08:33 AM

Interfaces cannot be serialized directly. Abstract classes can be serialized but only if they do not contain non-static, non-transient fields or override the writeObject() and readObject() methods. Specific instances can be implemented through concrete classes that implement the interface or override writeObject() and readObject. Abstract class implementation of () method.

Serialization and deserialization of golang function types Serialization and deserialization of golang function types Apr 29, 2024 am 08:15 AM

GoLang function types can be serialized and deserialized through the encoding/gob package. Serialization: Register a custom type and use gob.NewEncoder to encode the function type into a byte array. Deserialization: Use gob.NewDecoder to deserialize function types from byte arrays.

See all articles