Heim >Java >javaLernprogramm >Serialisierung und Deserialisierung von Java-Objekten
Das Beispiel in diesem Artikel beschreibt die Serialisierung und Deserialisierung von Java-Objekten als Referenz. Der spezifische Inhalt lautet wie folgt:
Was ist Serialisierung?
Konvertieren Sie das Objekt in einen Byte-Stream und speichern Sie es B. das Speichern in einer Datei und das spätere Wiederherstellen des Objekts. Dieser Mechanismus wird als Objektserialisierung bezeichnet. (Zusätzlicher Satz: Das Speichern von Objekten auf permanenten Speichergeräten wird als Persistenz bezeichnet)
2. So implementieren Sie die Serialisierung
Sie müssen die Serializable-Schnittstelle implementieren, was bedeutet, dass das Objekt dieser Klasse ist serialisierbar.
3. Hinweise zur Serialisierung
(1) Wenn ein Objekt serialisiert wird, können nur die nicht statischen Mitgliedsvariablen des Objekts gespeichert werden, Methoden und statische Mitgliedsvariablen jedoch nicht gerettet werden.
(2) Objekt A bezieht sich auf Objekt B, Objekt A wird serialisiert und B wird ebenfalls serialisiert.
(3) Wenn ein serialisierbares Objekt einen Verweis auf ein nicht serialisierbares Objekt enthält, schlägt der gesamte Serialisierungsvorgang fehl, und wenn er fehlschlägt, wird eine NotSerializableException ausgelöst. Daher müssen sowohl das Objekt selbst als auch das Referenzobjekt implementiert werden Die Serialisierbare Schnittstelle kann serialisiert werden.
(4) Bei Verwendung von transient wird die Mitgliedsvariable oder Referenz als transient markiert, dann kann das Objekt weiterhin serialisiert werden, es wird jedoch nicht in die Datei serialisiert.
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); } } }
Ausgabeergebnis:
---------
zhangsan-0
lisi-0
5. Feinere Kontrolle der Serialisierung und Deserialisierung
Wenn wir die beiden oben genannten privaten Methoden (Methoden) in der Serialisierungs- oder Deserialisierungsklasse implementieren, muss die Deklaration vollständig konsistent sein mit dem oben Gesagten), dann ermöglicht es uns, den Serialisierungs- und Deserialisierungsprozess auf einer niedrigeren Ebene und detaillierter zu steuern.
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er zum Lernen aller beiträgt, und ich hoffe auch, dass jeder die chinesische PHP-Website abonniert.
Weitere Artikel zur Serialisierung und Deserialisierung von Java-Objekten finden Sie auf der chinesischen PHP-Website!