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 !