Heim > Java > javaLernprogramm > Serialisierung und Deserialisierung von Java-Objekten

Serialisierung und Deserialisierung von Java-Objekten

高洛峰
Freigeben: 2017-01-18 11:29:21
Original
1337 Leute haben es durchsucht

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; 
 } 
}
Nach dem Login kopieren
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); 
  } 
 } 
}
Nach dem Login kopieren

Ausgabeergebnis:
---------
zhangsan-0
lisi-0
5. Feinere Kontrolle der Serialisierung und Deserialisierung

Serialisierung und Deserialisierung von Java-Objekten

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!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage