Sérialisation et désérialisation d'objets Java
L'exemple de cet article partage la sérialisation et la désérialisation des objets Java pour votre référence. Le contenu spécifique est le suivant
1 Qu'est-ce que la sérialisation
Convertissez l'objet en flux d'octets et enregistrez-le. , comme l'enregistrer dans un fichier et restaurer l'objet ultérieurement. Ce mécanisme est appelé sérialisation d'objet. (Phrase supplémentaire : l'enregistrement d'objets sur des périphériques de stockage permanents est appelé persistance)
2. Comment implémenter la sérialisation
Vous devez implémenter l'interface Serialisable. Si l'objet Java implémente cette interface, cela signifie que l'objet. de cette classe est sérialisable.
3. Notes sur la sérialisation
(1) Lorsqu'un objet est sérialisé, seules les variables membres non statiques de l'objet peuvent être enregistrées, mais les méthodes et les variables membres statiques ne le peuvent pas. être sauvé.
(2) L'objet A fait référence à l'objet B, l'objet A est sérialisé et B est également sérialisé.
(3) Si un objet sérialisable contient une référence à un objet non sérialisable, alors toute l'opération de sérialisation échouera et une NotSerializingException sera levée en cas d'échec. Par conséquent, l'objet lui-même et l'objet de référence doivent implémenter. l'interface sérialisable. Peut être sérialisée.
(4) L'utilisation de transitoire, la variable membre ou la référence est marquée comme transitoire, alors l'objet peut toujours être sérialisé, mais il ne sera pas sérialisé dans le fichier.
4. Code
public class Person implements Serializable { private String name; private transient int age; public Person(String name, int age) { super(); this.name = name; this.age = age; } public String toString() { return this.name + "-" + this.age; } }
public class SerializableClient { public static void main(String[] args) throws Exception { Person p1 = new Person("zhangsan", 5); Person p2 = new Person("lisi", 100); //序列化 FileOutputStream fos = new FileOutputStream("person.txt"); ObjectOutputStream oos = new ObjectOutputStream(fos); oos.writeObject(p1); oos.writeObject(p2); System.out.println("---------"); //反序列化 FileInputStream fis = new FileInputStream("person.txt"); ObjectInputStream ois = new ObjectInputStream(fis); for(int i = 0; i < 2; i++) { Person tempPerson = (Person)ois.readObject(); System.out.println(tempPerson); } } }
Résultat de sortie :
---------
zhangsan-0
lisi-0
5. Contrôle plus fin de la sérialisation et de la désérialisation
Lorsque nous implémentons les deux méthodes privées (méthodes) ci-dessus dans la classe de sérialisation ou de désérialisation, la déclaration doit être complètement cohérente. avec ce qui précède), cela nous permet alors de contrôler le processus de sérialisation et de désérialisation à un niveau inférieur et de manière plus granulaire.
Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'apprentissage de chacun, et j'espère également que tout le monde s'abonnera au site Web PHP chinois.
Pour plus d'articles liés à la sérialisation et à la désérialisation des objets Java, veuillez faire attention au site Web PHP chinois !

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Cet article analyse les quatre premiers cadres JavaScript (React, Angular, Vue, Svelte) en 2025, en comparant leurs performances, leur évolutivité et leurs perspectives d'avenir. Alors que tous restent dominants en raison de fortes communautés et écosystèmes, leur populaire relatif

L'article examine la mise en œuvre de la mise en cache à plusieurs niveaux en Java à l'aide de la caféine et du cache de goyave pour améliorer les performances de l'application. Il couvre les avantages de configuration, d'intégration et de performance, ainsi que la gestion de la politique de configuration et d'expulsion le meilleur PRA

Cet article aborde la vulnérabilité CVE-2022-1471 dans SnakeyAml, un défaut critique permettant l'exécution du code distant. Il détaille comment la mise à niveau des applications de démarrage de printemps vers SnakeyAml 1.33 ou ultérieurement atténue ce risque, en soulignant cette mise à jour de dépendance

Le chargement de classe de Java implique le chargement, la liaison et l'initialisation des classes à l'aide d'un système hiérarchique avec Bootstrap, Extension et Application Classloaders. Le modèle de délégation parent garantit que les classes de base sont chargées en premier, affectant la classe de classe personnalisée LOA

Node.js 20 améliore considérablement les performances via des améliorations du moteur V8, notamment la collecte des ordures et les E / S plus rapides. Les nouvelles fonctionnalités incluent une meilleure prise en charge de Webassembly et des outils de débogage raffinés, augmentant la productivité des développeurs et la vitesse d'application.

Iceberg, un format de table ouverte pour les grands ensembles de données analytiques, améliore les performances et l'évolutivité du lac Data. Il aborde les limites du parquet / orc par le biais de la gestion interne des métadonnées, permettant une évolution efficace du schéma, un voyage dans le temps, un W simultanément

Cet article explore l'intégration de la programmation fonctionnelle dans Java à l'aide d'expressions Lambda, de flux API, de références de méthode et facultatif. Il met en évidence des avantages tels que l'amélioration de la lisibilité au code et de la maintenabilité grâce à la concision et à l'immuabilité

Cet article explore les méthodes de partage des données entre les étapes du concombre, la comparaison du contexte de scénario, les variables globales, le passage des arguments et les structures de données. Il met l'accent
