Software Entwicklung 1

Ähnliche Dokumente
Software Entwicklung 1

Streams Software Entwicklung 1

Ein- und Ausgabe von Daten Software Entwicklung 1

Lösungshinweise/-vorschläge zum Übungsblatt 11: Software-Entwicklung 1 (WS 2017/18)

Programmieren I. Dateien: Allgemeines. Vorlesung 10. Handout S. 1. Martin Schultheiß. Hochschule Darmstadt Wintersemester 2010/2011

Datenströme in Java. Zeichenkonvertierung

Handbuch konsultieren!

Java I/O. Input / Output stream Library Regelt I/O über verschiedene Kanäle. Führt notwendige Umwandlungen/Konvertierungen aus

Dateien: Allgemeines Dateien lesen Beispiel: CSV-Daten Filter Ausgabe in Dateien. Programmieren I. Martin Schultheiß

Grundlagen der Programmierung! Kapitel 10: Ein- und Ausgabe! Ziele dieses Kapitels! Datei! Das Problem!

Eingabe und Ausgabe in Java. Dr. Horst Treiblmaier Abteilung für Wirtschaftsinformatik WU Wien

Einführung in die OOP mit Java Character-Streams Gliederung

Einstieg in die Informatik mit Java

Kapitel 12. Programmierkurs. Allgemeine Konzepte Byte-Streams versus Character-Streams

Ausnahmen. Annabelle Klarl. Einführung in die Informatik Programmierung und Softwareentwicklung

Ausnahmen. Dr. Philipp Wendler. Zentralübung zur Vorlesung Einführung in die Informatik: Programmierung und Softwareentwicklung

Ausnahmen. Annabelle Klarl. Einführung in die Informatik Programmierung und Softwareentwicklung

Ausnahmen. Philipp Wendler. Zentralübung zur Vorlesung Einführung in die Informatik: Programmierung und Softwareentwicklung

Programmieren in Java

Java I Vorlesung Exceptions

Software Entwicklung 1

Ausnahmen. Dr. Annabelle Klarl. Einführung in die Informatik Programmierung und Softwareentwicklung

Ausnahmen. Gilbert Beyer und Annabelle Klarl. Einführung in die Informatik. Zentralübung zur Vorlesung Einführung in die Informatik

Modellierung und Programmierung 1

Vorlesung Programmieren

1 Klassen anlegen und Objekte erzeugen

Dateien: Allgemeines Dateien lesen Beispiel: CSV-Daten Filter Ausgabe in Dateien. Programmieren I. Dr. Klaus Höppner

Software Entwicklung 1. Fallstudie: Arithmetische Ausdrücke. Rekursive Klassen. Überblick. Annette Bieniusa / Arnd Poetzsch-Heffter

Algorithmen und Programmierung III

1 Klassen anlegen und Objekte erzeugen

Java I/O. Input / Output stream Library Regelt I/O über verschiedene Kanäle. Führt notwendige Umwandlungen/Konvertierungen aus

Software Entwicklung 1

Ausnahmen und IO. Fehler, Ausnahmen, Java- Exception, throw, catch, Ströme, Puffer, Dateien lesen, schreiben, Tastatur, Terminal, HTTP

Java Fehlerbehandlung

Programmiermethodik 1. Klausur

Programmieren 2 Selbststudium Semesterwoche 6

Arten von Streams. Daten. Bytes (8-Bits) Java Programm. Daten. Java Programm. Characters (16 - Bits)

PROG 2: Einführung in die Programmierung für Wirtschaftsinformatiker

Ausnahmebehandlung PK11W-16,

Einstieg in die Informatik mit Java

Client-Server TCP/IP - Kodierung

Software Entwicklung 1

Vorlesung Programmieren. Java I/O: Input und Output mit Java. Ein-/Ausgabe von Daten. Java I/O. Heute. Grundlage fast aller Programme

Software Entwicklung 1

Grundlagen der Programmierung. Kapitel 10: Ein- und Ausgabe. Ziele dieses Kapitels. Das Problem. Datei

Grundlagen der Programmierung. Kapitel 11: Ein- und Ausgabe. Ziele dieses Kapitels. Das Problem. Datei

Grundlagen der Programmierung. Kapitel 11: Ein- und Ausgabe. Ziele dieses Kapitels. Das Problem. Datei

Javakurs für Fortgeschrittene

Objektorientierung II & die Java Klassenbibliothek. Kristian Bergmann und Arthur Lochstampfer

Software Entwicklung 1. Rekursion. Beispiel: Fibonacci-Folge I. Motivation. Annette Bieniusa / Arnd Poetzsch-Heffter

TECHNISCHE UNIVERSITÄT MÜNCHEN FAKULTÄT FÜR INFORMATIK

Institut für Programmierung und Reaktive Systeme. Java 6. Markus Reschke

Einstieg in die Informatik mit Java

JAVA für Einsteiger. Streams und Dateien. eden market Autor: Norman Lahme

Ausnahmen. Gerd Bohlender. Institut für Angewandte und Numerische Mathematik. Vorlesung: Einstieg in die Informatik mit Java 27.6.

Klausur Grundlagen der Programmierung

Einführung in C. Alexander Batoulis. 5. Mai Fakutltät IV Technische Universität Berlin

Java Einführung Exception Handling. Kapitel 17

Programmieren 2 09 File-IO

Fragenkatalog ESOP WS 16/17

Grundlagen der Programmierung! Kapitel 10: Ein- und Ausgabe! Ziele dieses Kapitels! Das Problem! Datei!

Dynamische Datenstrukturen Jiri Spale, Algorithmen und Datenstrukturen - Dynamische Datenstrukturen 1

Abschnitt 18: Beispiel: I/O-Streams

Vorlesung Programmieren

java.io Ziel Ressourcen Page 1 Verstehen der unterschiedlichen I / O Möglichkeiten Anwenden der Java I/ O Klassen Java Tutorial Java API Dokumentation

JAVA BASICS. 2. Primitive Datentypen. 1. Warum Java? a) Boolean (logische Werte wahr & falsch)

II.4.4 Exceptions - 1 -

Streams. Gerd Bohlender. Institut für Angewandte und Numerische Mathematik. Vorlesung: Einstieg in die Informatik mit Java

Teil 5 - Java. Programmstruktur Operatoren Schlüsselwörter Datentypen

! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete! 4. Ausnahmen (Exceptions) II.4.

Software Entwicklung 1

Software Entwicklung 1. Subtyping revisited. Subtypbildung in Java: Klassen I. Subtyping und Vererbung I. Annette Bieniusa / Arnd Poetzsch-Heffter

Java Übung. Übung 3. Werner Gaulke. 2. Mai Universität Duisburg-Essen Kommedia, Übung EinPro SS06, Einführung in Java - Übung.

Tag 8 Repetitorium Informatik (Java)

Ein- und Ausgabe in Java

Distributed Computing Group

Umleitung von Datenströmen

Software Entwicklung 1

Java-Schulung Grundlagen

Info B VL 7: Input/Output

Programmierung für Mathematik HS11

Modularisierung in Java: Pakete Software Entwicklung 1

Ausdrucksbäume in verschiedenen Darstellungen

Kapitel 15: Ausnahmen und

Grundlagen der Informatik / Algorithmen und Datenstrukturen. Aufgabe 139

Institut für Programmierung und Reaktive Systeme. Java 2. Markus Reschke

3.11 Ausnahmen und Ein-/Ausgabe

Einführung Datentypen Verzweigung Schleifen Funktionen Dynamische Datenstrukturen. Java Crashkurs. Kim-Manuel Klein

11. Funktionale Konzepte in Java

Name: Matrikelnr : Aufgabe 1: (ca. 8 Punkte )

Programmieren 2 09 File-IO

Java Einführung IO (Eingabe/Ausgabe)

AuD-Tafelübung T-B5b

Johannes Unterstein - TINF16 - Java - Sommersemester 2017 JAVA. Wiederholung

Transkript:

Software Entwicklung 1 Annette Bieniusa / Arnd Poetzsch-Heffter AG Softech FB Informatik TU Kaiserslautern

Ströme zur Ein- und Ausgabe Bieniusa/Poetzsch-Heffter Software Entwicklung 1 2/ 44

Ströme zur Ein- und Ausgabe I Ein- und Ausgabe von Daten wird heutzutage meist durch Ströme modelliert. Begriffsklärung: Datenstrom Ein Strom (engl. Stream) ist eine potentiell unendliche Folge von Daten. Er wird von einer oder mehrerer Quellen mit Daten versorgt und erlaubt es, diese Daten der Reihe nach aus dem Strom herauszulesen. Das Ende eines Stromes wird durch ein spezielles Datum markiert (z.b. in Java bei char-strömen -1). Bieniusa/Poetzsch-Heffter Software Entwicklung 1 3/ 44

Ströme zur Ein- und Ausgabe II Bei Operationen auf einem Strom kann es zu Verzögerungen kommen: beim Lesen, weil augenblicklich kein Zeichen vorhanden, der Strom aber noch nicht zu Ende ist; beim Schreiben, weil evtl. kein Platz im Strom vorhanden ist. Die Verzögerungen führen zu einer Blockierung der ausgeführten Methode. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 4/ 44

Einführung in Ströme I Wir betrachten zunächst Ströme zum Lesen: interface CharEingabeStrom { int read () throws IOException ; Bieniusa/Poetzsch-Heffter Software Entwicklung 1 5/ 44

Einführung in Ströme II Diese Schnittstelle abstrahiert von der Quelle aus der gelesen wird. Mögliche Quellen: 1 Datenstruktur wie Array, Liste, String 2 Datei 3 Netzwerk 4 Standardeingabe, z.b. interaktive Eingabe vom Anwender 5 andere Programme 6 andere Ströme Wir betrachten hier die Fälle 1, 2 und 6. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 6/ 44

Lesen aus einer Datenstruktur Wir betrachten das schrittweise Lesen der Zeichen eines Strings. Die Quelle des Stroms wird dem Konstruktor übergeben. public class StringLeser implements CharEingabeStrom { private char [] zeichen ; private int index = 0; public StringLeser ( String s ) { zeichen = s. tochararray (); public int read () { if ( index == zeichen. length ) { return -1; else { return zeichen [ index ++]; Bieniusa/Poetzsch-Heffter Software Entwicklung 1 7/ 44

Zusammenbauen von Strömen I Wir betrachten zwei Stromklassen, die aus anderen Strömen lesen und die Ströme modifizieren. Die Konstruktoren nehmen dabei einen beliebigen CharEingabeStrom als Quelle: Subtyping at its best! Bieniusa/Poetzsch-Heffter Software Entwicklung 1 8/ 44

Zusammenbauen von Strömen II public class GrossBuchstabenFilter implements CharEingabeStrom { private CharEingabeStrom eingabestrom ; public GrossBuchstabenFilter ( CharEingabeStrom cs ) { eingabestrom = cs; public int read () throws IOException { int z = eingabestrom. read (); if( z == -1 ) { return -1; else { return Character. touppercase ( ( char ) z ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 9/ 44

Zusammenbauen von Strömen III public class UmlautSzFilter implements CharEingabeStrom { private CharEingabeStrom eingabestrom ; private int puffer = -1; public UmlautSzFilter ( CharEingabeStrom cs ){ eingabestrom = cs; public int read () throws IOException { if( puffer!= -1 ) { int z = puffer ; puffer = -1; return z; else {... Bieniusa/Poetzsch-Heffter Software Entwicklung 1 10/ 44

Zusammenbauen von Strömen IV int z = eingabestrom. read (); if( z == -1 ) return -1; switch ( ( char )z ) { case \ u00c4 : puffer = e ; return A ; case \ u00d6 : puffer = e ; return O ; case \ u00dc : puffer = e ; return U ; case \ u00e4 : puffer = e ; return a ; case \ u00f6 : puffer = e ; return o ; case \ u00fc : puffer = e ; return u ; case \ u00df : puffer = s ; return s ; default : return z; Folgendes Programm zeigt Zusammenbau und Anwendung von Strömen: Bieniusa/Poetzsch-Heffter Software Entwicklung 1 11/ 44

Zusammenbauen von Strömen V public class S treamte stmain { public static void main ( String [] args ) throws IOException { String s = new String ("\ u00c4neas opfert den " + " G\ u00d6ttern edle \ u00d6le,\ nauf da\ u00df " + "\ u00fcberall das \ u00dcbel sich \ u00e4ndert."); CharEingabeStrom cs = new StringLeser ( s ); cs = new Uml autszfil ter ( cs ); cs = new GrossBuchstabenFilter ( cs ); int z = cs. read (); while ( z!= -1 ) { System. out. print ( ( char )z ); z = cs. read (); System. out. println (); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 12/ 44

Javas Stromklassen I Stromklassen werden nach den Datentypen, die sie verarbeiten, und ihren Datenquellen bzw. -senken klassifiziert. Stromklassen sind wichtige programmiertechnische Hilfsmittel. Die Reader-/Writer-Klassen aus dem Paket java.io verarbeiten char-ströme; die Input-/Output-Stromklassen verarbeiten byte-ströme. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 13/ 44

Javas Stromklassen II Die Reader-Klassen unterstützen: das Lesen einzelner Zeichen: int read(); das Lesen mehrerer Zeichen aus der Quelle und Ablage in ein char-array: int read(char[]); das Überspringen einer Anzahl von Zeichen der Eingabe: long skip(long); die Abfrage, ob der Strom für das Lesen des nächsten Zeichens bereit ist; das Schließen des Eingabestroms: void close(); Methoden zum Markieren und Zurücksetzen des Stroms. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 14/ 44

Javas Stromklassen III Die Writer-Klassen unterstützen: das Schreiben einzelner Zeichen: void write ( int ); das Schreiben mehrerer Zeichen eines char-arrays: void write ( char []) u. ä.; das Schreiben mehrerer Zeichen eines String: void write ( String ) u. ä.; die Ausgabe ggf. im Strom gepufferter Zeichen: void flush () ; Bieniusa/Poetzsch-Heffter Software Entwicklung 1 15/ 44

Javas Stromklassen IV das Schließen des Ausgabestroms: void close () Die genannten Methoden lösen möglicherweise eine IOException aus. Die von InputStream bzw. OutputStream abgeleiteten Klassen leisten Entsprechendes für Daten vom Typ byte. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 16/ 44

Reader-/Writer-Klassen I Die Reader-Klassen unterscheiden sich im Wesentlichen durch ihre Quelle: Reader-Klasse Quelle Bemerkung InputStreamReader InputStream FileReader byte-strom aus Datei BufferedReader Reader puffernd; können LineNumberReader Reader zeilenweise lesen PipedReader PipedWriter FilterReader Reader PushBackReader Reader Methode unread CharArrayReader char[] StringReader String Bieniusa/Poetzsch-Heffter Software Entwicklung 1 17/ 44

Reader-/Writer-Klassen II Writer arbeiten analog zu Reader-Klassen, nur in umgekehrter Richtung. PrintWriter unterstützen die formatierte Ausgabe von Daten durch die Methoden print und println, die alle Standarddatentypen als Parameter nehmen. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 18/ 44

Bemerkung Die Konstruktoren ermöglichen das Zusammenhängen von Strömen; hier am Beispiel eines Konstruktors der Klasse PrintWriter: public PrintWriter ( OutputStream o, boolean af) { this ( new BufferedWriter ( new OutputStreamWriter (o)), af); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 19/ 44

Beispiel: Reader-/Writer-Klassen I public class DateiZugriff { public static String lesen ( String datei ) throws FileNotFoundException, IOException { BufferedReader in = new BufferedReader ( new FileReader ( datei )); String line, inputstr = ""; line = in. readline (); while ( line!= null ){ inputstr = inputstr. concat ( line +"\n"); line = in. readline (); in. close (); return inputstr ; Bieniusa/Poetzsch-Heffter Software Entwicklung 1 20/ 44

Beispiel: Reader-/Writer-Klassen II public static void schreiben ( String datei, String s) throws IOException { PrintWriter out = new PrintWriter ( new FileWriter ( datei ) ); out. print (s); out. close (); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 21/ 44

Beispiel: Reader-/Writer-Klassen III public class DateiZugriffTest { public static void main ( String [] args ){ String s; try { s = DateiZugriff. lesen ( argf [0] ); catch ( FileNotFoundException e ){ System. out. println (" Can t open "+ args [0]) ; return ; catch ( IOException e ){ System. out. println (" IOException : "+ args [0]) ; return ; Bieniusa/Poetzsch-Heffter Software Entwicklung 1 22/ 44

Beispiel: Reader-/Writer-Klassen IV try { DateiZugriff. schreiben (" ausgabedatei ",s); catch ( IOException e ){ System. out. println (" Can t open "+ args [0] ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 23/ 44

Schließen von Strömen I Ströme müssen geschlossen werden, wenn sie nicht mehr verwendet werden. Um dies sicherzustellen, wenn während der Verwendung des Stroms eine Exception auftritt, muss die Anweisung in einem try-finally Block verwendet werden. BufferedReader reader = null ; try { reader = new BufferedReader (...) ; // Strom verwenden finally { if ( reader!= null ) { reader. close (); Der finally-block wird immer nach dem try-block ausgeführt. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 24/ 44

Schließen von Strömen II Java 7 bietet eine alternative Syntax für die Deklaration und Verwendung von Strömen an: try ( BufferedReader reader = new BufferedReader (...) ) { // Strom verwenden Dieses Konstrukt sorgt dafür, dass der Strom automatisch am Ende des try-blocks geschlossen wird. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 25/ 44

Ein- und Ausgabe von Objekten Bieniusa/Poetzsch-Heffter Software Entwicklung 1 26/ 44

Ein- und Ausgabe von Objekten I Wir haben gesehen, wie wir byte- und char-werte in Ströme schreiben und von Strömen lesen können. Nun wollen wir uns ansehen, wie wir Objekte in ein entsprechendes Format umwandeln können. Serialisieren bedeutet einen Wert eins Typs in Bytes umzuwandeln. Deserialisieren bezeichnet den umgekehrten Prozess. Die Serialisieren und Deserialisieren von Objekten ist komplex: Der Zustand reicht zur Repräsentation eines Objektes nicht aus. Objektreferenzen besitzen nur innerhalb des aktuellen Prozesses eine Gültigkeit. Bei Objekten ist häufig ihre Rolle im Objektgeflecht von entscheidender Bedeutung. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 27/ 44

Ein- und Ausgabe von Objekten II Andererseits ist Ein- und Ausgabe von Objekten wichtig, um Objekte zwischen Prozessen auszutauschen; Objekte für nachfolgende Programmläufe zu speichern, d.h. persistent zu machen. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 28/ 44

Beispiel: Ausgabe von Objekten I public class TodoList { private List < Task > tasks ; public TodoList () { this. tasks = new LinkedList < >(); public void addtask ( String desc, Date da) {... public class Task { private description ; private Date ;... // Getter und Setter TodoList tdl = new TodoList (); tdl. add (" Lernen ", new Date (9,3,2016) ); tdl. add (" Einkaufen ", new Date (1,2,2016) ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 29/ 44

Beispiel: Ausgabe von Objekten II Was bedeutet es, das von ll referenzierte Objekt auszugeben(?): nur das TodoList-Objekt ausgeben; das TodoList-Objekt und die zugehörigen Task-Objekte ausgeben; das TodoList-Objekt, die zugehörigen Task-Objekte sowie die String-Objekte und das Date-Objekt ausgeben. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 30/ 44

Ausgabe von Objektgeflechten Um Objekte in ihrem Zusammenwirken mit anderen Objekten wieder einlesen zu können, müssen sie gemeinsam mit allen erreichbaren Objekten ausgegeben werden. Wegen möglicher Zyklen ist die Implementierung der Ausgabe und des Einlesens von Geflechten nicht einfach. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 31/ 44

Bemerkung Gibt man ein Objekt mit den erreichbaren Objekten aus und liest es wieder ein, entsteht eine Kopie. Referenziert man von mehreren Variablen Teile des gleichen Geflechts, kommt es beim Einlesen ggf. zu mehreren Kopien eines Objekts des ursprünglichen Geflechts. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 32/ 44

JSON JSON (JavaScript Object Notation) ist ein leichtgewichtiges Datenaustauschformat. Es ist einfach für Menschen zu lesen und gleichzeitig einfach für Maschinen zu parsen und generieren. JSON baut auf zwei Arten von Strukturen auf: Eine Sammlung von Name-Wert-Paaren (ähnlich einer Map); JSON object Eine geordnete Liste von Werten; JSON array Bieniusa/Poetzsch-Heffter Software Entwicklung 1 33/ 44

JSON Syntax Bieniusa/Poetzsch-Heffter Software Entwicklung 1 34/ 44

Gson Gson ist ein Java-Bibliothek zur Erzeugung von JSON Repräsentationen von Objekten. Die Bibliothek enthält sowohl Unterstützung für die direkte Beschreibung der zu erzeugenden JSON Ausgabe und die Umwandlung von Java-Objekten in JSON entsprechende Methoden zum parsen von JSON Bieniusa/Poetzsch-Heffter Software Entwicklung 1 35/ 44

Direkte Beschreibung von JSON I Für jedes Element in der JSON-Syntax gibt es eine Java-Klasse, die dieses Element repräsentiert. JsonElement JsonArray JsonObject JsonPrimitive JsonNull Mit Objekten dieser Klassen können JSON-Ausgaben beschrieben werden. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 36/ 44

Direkte Beschreibung von JSON II Gson gson = new Gson (); JsonObject university = new JsonObject (); university. addproperty (" name ", "TU JsonArray courses = new JsonArray (); courses. add ("SE 1"); courses. add ("SE 2"); courses. add ("SE 3"); courses. add (" Insy "); university. add (" courses ", courses ); KL"); {" name ":"TU KL", " courses ": ["SE 1", "SE 2", "SE 3", " Insy "] gson. tojson ( university ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 37/ 44

Direkte Beschreibung von JSON III JsonParser parser = new JsonParser (); JsonObject parseduni = parser. parse ( jsonstring ). getasjsonobject (); assertequals ( parseduni. get (" name "). getasstring (), "TU KL"); JsonArray parsedcourses = parseduni. get (" courses "). getasjsonarray (); assertequals ( parsedcourses. get (0). getasstring (), "SE 1"); assertequals ( parsedcourses. get (1). getasstring (), "SE 2"); assertequals ( parsedcourses. get (2). getasstring (), "SE 3"); assertequals ( parsedcourses. get (3). getasstring (), " Insy "); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 38/ 44

Direkte Beschreibung von JSON IV Code stimmt mit ausgegebenem JSON überein Struktur direkt beeinflussbar Volle Kontrolle, somit auch bei genauen Vorgaben des Ausgabeformats Zyklen im Objektgeflecht Bieniusa/Poetzsch-Heffter Software Entwicklung 1 39/ 44

Umwandlung von Java-Objekten in JSON I Für viele Java-Objekte ist die Relation zwischen dem Objekt im Speicher und der Ausgabe als JSON klar: Objekte werden als JSON-Objekt, Attribute von Objekten werden als Eigenschaften (properties) des JSON Objects, Listen und Arrays werden als JSON arrays und Maps werden ebenfalls als JSON object ausgegeben. Reichen diese Konventionen aus, kann Gson die Konvertierung in der Regel automatisch durchführen. Bieniusa/Poetzsch-Heffter Software Entwicklung 1 40/ 44

Umwandlung von Java-Objekten in JSON II public class University { private String name ; private List < String > courses ; public University ( String name ) { this. name = name ; this. courses = new ArrayList < >(); public void addcourse ( String course ) { this. courses. add ( course ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 41/ 44

Umwandlung von Java-Objekten in JSON III Gson gson = new Gson (); University unikl = new University (" TU KL"); unikl. addcourse ("SE 1"); unikl. addcourse ("SE 2"); unikl. addcourse ("SE 3"); unikl. addcourse (" Insy "); String json = gson. tojson ( unikl ); University parseduni = gson. fromjson (json, University. class ); assertequals ( parseduni, unikl ); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 42/ 44

Bemerkungen I Benutzerdefinierte Übersetzungen von Java-Klassen können als Subtypen von JsonSerializer<T> (von T nach JSON) und JsonDeserializer<T> (von JSON nach T) implementiert werden. public class UniSerializer implements JsonSerializer < University > { public JsonElement serialize ( University uni, Type type, JsonSerializationContext context ) {... Instanzen dieser Klassen können in Gson wie folgt eingebunden werden: GsonBuilder builder = new GsonBuilder (); builder. registertypeadapter ( University. class, new UniSerializer ()); builder. registertypeadapter ( University. class, new UniDeserializer ()); Gson gson = builder. create (); Bieniusa/Poetzsch-Heffter Software Entwicklung 1 43/ 44

Bemerkungen II JSON kann direkt auf einen Writer geschrieben oder von einem Reader gelesen werden: // schreibe das University Objekt unikl in Datei unikl. json gson. tojson ( unikl, new JsonWriter ( new FileWriter (" unikl. json "))) // lies das University Objekt aus der Datei unikl. json gson. fromjson ( new FileReader (" unikl. json "), University. class ) Bieniusa/Poetzsch-Heffter Software Entwicklung 1 44/ 44