Maison  >  Article  >  Java  >  Explication détaillée de la sérialisation et de la désérialisation d'objets en Java

Explication détaillée de la sérialisation et de la désérialisation d'objets en Java

高洛峰
高洛峰original
2017-01-18 10:42:081128parcourir

La sérialisation est le processus de conversion des informations d'état d'un objet en une forme pouvant être stockée ou transmise. Généralement, un objet est stocké dans un support de stockage, tel qu'un fichier ou une mémoire tampon. Lors de la transmission réseau, il peut être au format octet ou XML. Les formats de codage octet ou XML peuvent restaurer des objets exactement équivalents. Ce processus inverse est également appelé désérialisation.
Sérialisation et désérialisation d'objets Java
En Java, nous pouvons créer des objets de plusieurs manières, et nous pouvons réutiliser l'objet tant que l'objet n'est pas recyclé. Cependant, ces objets Java que nous créons existent dans la mémoire tas de la JVM. Ces objets ne peuvent exister que lorsque la JVM est en cours d'exécution. Une fois que la JVM cesse de fonctionner, l'état de ces objets est perdu.
Mais dans des scénarios d'application réels, nous devons conserver ces objets et pouvoir les relire en cas de besoin. La sérialisation des objets Java peut nous aider à réaliser cette fonction.
Le mécanisme de sérialisation d'objet (sérialisation d'objet) est une méthode de persistance d'objet intégrée au langage Java. Grâce à la sérialisation d'objet, l'état de l'objet peut être enregistré sous forme de tableau d'octets et ce mot peut être utilisé en cas de besoin. Le tableau de sections est converti en objet par désérialisation. La sérialisation des objets facilite la conversion entre les objets actifs et les tableaux d'octets (flux) dans la JVM.
En Java, la sérialisation et la désérialisation d'objets sont largement utilisées dans le RMI (invocation de méthode à distance) et la transmission réseau.
Interfaces et classes pertinentes
Java fournit un ensemble de supports d'API pratiques permettant aux développeurs de sérialiser et de désérialiser les objets Java. Il comprend les interfaces et classes suivantes : 🎜> ObjectOutputStream

ObjectInputStream

Interface sérialisable

La classe implémente l'interface java.io.Seriallessly pour activer sa fonction de sérialisation. . Une classe qui n’implémente pas cette interface ne pourra sérialiser ou désérialiser aucun de ses états. Tous les sous-types d'une classe sérialisable sont eux-mêmes sérialisables. L'interface de sérialisation n'a ni méthode ni champ et est utilisée uniquement pour identifier la sémantique sérialisable. (Cette interface n'a ni méthodes ni champs. Pourquoi seuls les objets des classes qui implémentent cette interface peuvent-ils être sérialisés ?)

Lorsque vous essayez de sérialiser un objet, si vous rencontrez un objet qui ne prend pas en charge l'interface Serialisable. Dans ce cas, NotSerializingException sera levée.

Si la classe à sérialiser a une classe parent et que vous souhaitez conserver les variables définies dans la classe parent en même temps, la classe parent doit également intégrer l'interface java.io.Serializing.

Ce qui suit est une classe qui implémente l'interface java.io.Seriallessly

La sérialisation et la désérialisation sont effectuées via le code suivant


Ce qui précède est l'intégralité de l'article Contenu, j'espère qu'il sera utile à tout le monde d'apprendre la sérialisation et la désérialisation d'objets en Java.

Pour des articles plus détaillés sur la sérialisation et la désérialisation d'objets en Java, veuillez faire attention au site Web PHP chinois !

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn