Maison > Java > javaDidacticiel > Sérialisation et désérialisation d'objets Java

Sérialisation et désérialisation d'objets Java

高洛峰
Libérer: 2017-01-18 11:29:21
original
1330 Les gens l'ont consulté

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; 
 } 
}
Copier après la connexion
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); 
  } 
 } 
}
Copier après la connexion

Résultat de sortie :
---------
zhangsan-0
lisi-0
5. Contrôle plus fin de la sérialisation et de la désérialisation

Sérialisation et désérialisation dobjets Java

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 !

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal