What is serialization? A detailed introduction to 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:
- 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.
- #Fields modified by transient cannot be serialized.
OutputStream ops=new FileOuptStream(path);
ObjectOuptStream oos=new ObjectOutputStream(ops);
Object obj=new Ojbect();
oos.writeObject(obj);
Copy after login
OutputStream ops=new FileOuptStream(path); ObjectOuptStream oos=new ObjectOutputStream(ops); Object obj=new Ojbect(); oos.writeObject(obj);
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 ismodified, 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
InputStream is=new FileInputStream(path); ObjectInputStream ois=new ObjectIputStream(is); Object obj=ois.readObject();
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!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

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

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.

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 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?

@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

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

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.

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.
