Die Präsentation wird geladen. Bitte warten

Die Präsentation wird geladen. Bitte warten

Institut für Kartographie und Geoinformation Prof. Dr. Lutz Plümer, Dr. Gerhard Gröger, Dipl.-Ing. D. Dörschlag Einführung in die Programmierung mit Java.

Ähnliche Präsentationen


Präsentation zum Thema: "Institut für Kartographie und Geoinformation Prof. Dr. Lutz Plümer, Dr. Gerhard Gröger, Dipl.-Ing. D. Dörschlag Einführung in die Programmierung mit Java."—  Präsentation transkript:

1 Institut für Kartographie und Geoinformation Prof. Dr. Lutz Plümer, Dr. Gerhard Gröger, Dipl.-Ing. D. Dörschlag Einführung in die Programmierung mit Java 7. Vorlesung WS 2003/2004

2 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/042 Übersicht Die Klasse String - Benutzung von Methoden und Arbeiten mit JavaDoc Statische Attribute (Klassenvariablen) Statische Methoden (Klassenmethoden)

3 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/043 Hausaufgabe Definiert eine Klasse für Dreiecke, die in der Ebene eingebettet sind (d.h. alle drei Punkte haben x- und y- Koordinaten). Definiert –einen komfortablen Konstruktor (der ein Dreieck in einem Schritt erzeugt) –eine Methode zur Berechnung des Umfangs, –eine Methode zum Verschieben des Dreiecks und –eine Methode zur textuellen Ausgabe.

4 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/044 Lösung (I von II): class Dreieck{ //Attribute (x und y für drei Eckpunkte des Dreiecks) double punktAx, punktAy, punktBx, punktBy, punktCx, punktCy; //Konstruktor Dreieck(double Ax, double Ay, double Bx, double By, double Cx, double Cy){ punktAx = Ax; punkt Ay = Ay, punktBx = Bx; punktBy = By; punktCx = Cx; punktCy = Cy); //Methode zur Berechnung des Umfangs double umfang(){ double u = Math.sqrt(Math.pow(punktAx - punktBx,2.0) + Math.pow(punktAy - punktBy,2.0)) + Math.sqrt(Math.pow(punktBx - punktCx,2.0) + Math.pow(punktBy - punktCy,2.0)) + Math.sqrt(Math.pow(punktCx - punktAx,2.0) + Math.pow(punktCy - punktAy,2.0)); return u; }..................... A B C

5 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/045 Lösung (II von II):....... //Methode zur Verschiebung um deltaX, deltaY double verschieben(double deltaX, double deltaY){ punktAx = punktAx + deltaX; punktAy = punktAy + deltaY; punktBx = punktBx + deltaX; punktBy = punktBy + deltaY; punktCx = punktCx + deltaX; punktCy = punktCy + deltaY;} //Methode zur textuellen Ausgabe void ausgabe(){ System.out.println("Die Punkte des Dreiecks haben die Koordinaten " + punktAx + ", " + punktAy + ", " + punktBx + ", " + punktBy + ", " + punktCx + ", " + punktCy); } A B C

6 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/046 Beispiel: Klasse Punkt class Punkt{ double xKoordinate; double yKoordinate; Punkt(){ xKoordinate = 0.0; yKoordinate = 0.0;} Punkt(double x, double y ){xKoordinate = x; yKoordinate = y;} double x_Koordinate() {return xKoordinate;} double y_Koordinate() {return yKoordinate;} void aendereKoordinaten(double x, double y){ xKoordinate = x; yKoordinate = y;} void verschieben(double deltaX, double deltaY) { xKoordinate = xKoordinate + deltaX; yKoordinate = yKoordinate + deltaY;} double abstand(Punkt p){ double a = Math.sqrt(Math.pow(xKoordinate - p.xKoordinate,2.0) + Math.pow(yKoordinate - p.yKoordinate,2.0)); return a; }

7 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/047 Alternative Lösung mit Klasse Punkt: class Dreieck{ Punkt A; //Attribute, drei Punkte Punkt B; Punkt C; Dreieck(double Ax, double Ay, double Bx, double By, double Cx, double Cy){ A = new Punkt(Ax, Ay);//Aufruf des Konstruktors der Klasse Punkt B = new Punkt(Bx, By); C = new Punkt(Cx, Cy); } double umfang(){ //Verwendung der Methode "abstand" der Klasse "Punkt" double u = A.abstand(B) + B.abstand(C) + C.abstand(A); return u; } void verschieben(double deltaX double deltaY){ A.verschieben(deltaX, deltaY); //Methode "verschieben" der Klasse "Punkt" B.verschieben(deltaX, deltaY); C.verschieben(deltaX, deltaY); } void ausgabe(){... } }

8 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/048 Anmerkungen zur Hausaufgabe Attribute von Klassen können wieder Klassen sein –Bsp: Klasse Dreieck hat Attribute A, B, C vom Typ Punkt diese Attribute müssen mit "new" erzeugt werden –Bsp.: A = new Punkt(Ax, Ay); –dies geschieht im Konstruktor Nutzung der Funktionalität der enthaltenen Klasse –Bsp.: Nutzung der Methode abstand der Klasse Punkt bei Ermittlung des Umfangs in Klasse Dreieck Wiederverwendung von Programmcode

9 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/049 Übungsaufgabe Ergänzt die Klasse Dreieck aus der Hausaufgabe um eine Methode, die den Flächeninhalt eines Dreiecks berechnet und zurückgibt. Hinweis: Der Flächeninhalt eines Dreiecks ist: Flächeninhalt = 1/2 * ( ( Ax (By - Cy) + Bx (Cy - Ay) + Cx ( Ay - By)) A B C

10 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0410 Übungsaufgabe Ergänzt die Klasse Dreieck aus der Hausaufgabe um eine Methode, die ermittelt, ob zwei Dreiecke über einen Punkt benachbart sind (d.h. einer der drei Eckpunkte des einen Dreiecks mit einem der drei Eckpunkte des anderen geometrisch übereinstimmt). Der Rückgabewert der Methode soll vom Typ boolean sein.

11 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0411 Lösung (Alternative 1) : class Dreieck{....... boolean benachbart(Dreieck d){ if(A.abstand(d.A) == 0 ) return true; if(A.abstand(d.B) == 0 ) return true; if(A.abstand(d.C) == 0 ) return true; if(B.abstand(d.A) == 0 ) return true; if(B.abstand(d.B) == 0 ) return true; if(B.abstand(d.C) == 0 ) return true; if(C.abstand(d.A) == 0 ) return true; if(C.abstand(d.B) == 0 ) return true; if(C.abstand(d.C) == 0 ) return true; return false; }

12 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0412 Fortsetzung Lösung (Alternative 1) : //Aufruf: Dreieck d1 = new Dreieck(4.3, 9.8, 2.1, 7.5, 6.9, 4.3); Dreieck d2 = new Dreieck(5.2, 2.1, 4.3, 4.3, 9.8, 2.1); boolean b = d1.benachbart(d2); if(b) System.out.println("Dreiecke sind benachbart");

13 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0413 Lösung (Alternative 2) : class Dreieck{....... boolean benachbart(Dreieck d){ if(A.xKoordinate == d.A.xKoordinate & A.yKoordinate == d.A.yKoordinate) return true; if(A.xKoordinate == d.B.xKoordinate & A.yKoordinate == d.B.yKoordinate) return true;................................. // alle 9 Fälle müssen berücksichtigt werden return false; }

14 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0414 Anmerkung zur Übungsaufgabe : class Dreieck{....... boolean benachbart(Dreieck d){ if( A == d.A ) return true; if( A == d.B ) return true;................. if( C == d.C ) return true; return false; } // Diese Lösung ist falsch, da die Referenzvariablen und nicht // die Attributwerte der Instanzen (xKoordinate, yKoordinate) // auf Gleichheit überprüft werden

15 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0415 Nutzung von Methoden: die Klasse String Zweck der Klasse String: Speicherung und Bearbeitung von Zeichenketten (Wörter, Sätze) Beispiel: String s1 = "Das ist das Haus"; String s2 = "Nikolaus."; String s3 = s1 + " vom " + s2; //in s3 steht:"Das ist das Haus vom Nikolaus."; String s4 = s3.substring(12,16); // in s4 steht: "Haus" Strings sind konstant (können nicht geändert werden) –sie müssen nicht mit new erzeugt werden –Stringvariablen können jedoch geändert werden, z.B. s1 = "abc"; in obigem Beispiel.

16 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0416 Die Klasse String Erzeugung einer Instanz: –String variable = “Zeichenkette“; Operator +: Konkatenation von Zeichenketten –String s1 = “ABC“ + variable + “DEF“; Nützliche Methoden der Klasse String: –“Geoinformation“.length() liefert 14 –“ ABCD “.trim() liefert “ABCD“ –"Geoinformation".substring(3,7) liefert "info“ –"Institution".indexOf("ti") liefert 3 Weitere Methoden: JavaDoc

17 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0417 Übungsaufgabe Schreibt ein Programm, das euren Vor- und Nachnamen mit einem Leerzeichen getrennt einer String-Variablen zuweist. Leitet aus diesem String durch entsprechende Methoden der Klasse String folgendes ab: –einen String, der nur den Vornamen enthält –einen String, der nur den Nachnamen enthält –einen String mit Nach- und Vornamen (mit Komma dazwischen) –die Anzahl der Buchstaben des Strings (ohne Leerzeichen) –einen String, in dem das erste Vorkommen von ä, ö, ü durch ae, oe, ue ersetzt wurde Das Programm soll natürlich für jeden Vor- und Nachnamen funktionieren.....

18 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0418 Statische Attribute die bisher behandelten Attribute (nicht-statische Attribute) existieren einmal pro Instanz nicht möglich, Informationen zur Klasse abzuspeichern (z.B. Anzahl der Instanzen; Werte, die für jede Instanz der Klasse gleich sind,...) statische Attribute: existieren einmal pro Klasse, für alle Instanzen derselbe Wert Zweck: Speicherung Klassen-globaler Informationen Syntax: class Klassenbezeichner { static Typ Attributbezeichner ;... }

19 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0419 Zugriff auf statische Attribute Zugriff auf nicht-statische Attribute: –es muss Instanz der Klasse (Referenzvariable) existieren –Zugriff von Außen: Referenzvariable.attribut –Zugriff von Innen: attribut Zugriff auf statische Attribute: –es muss nicht unbedingt eine Instanz der Klasse existieren –Zugriff von Außen: Klassenname.attribut –oder Zugriff wie bei nicht-statischen Attributen Beispiel: class MeineKlasse { static int v1; }.......... MeineKlasse.v1 = 40 ;

20 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0420 Statische Attribute: eine Klasse und Ihre Instanzen Klasse static int s = 7 int n Instanz n = 65 Instanz n = 25 Instanz n = 4 Instanz n = 76 Bauplan

21 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0421 Zugriff auf statische Attribute: Beispiel class MeineKlasse { static int s; //statisches Attribut int n; //nicht-statisches Attribut void methode(){ n = 4; //nicht-stat.Attribut, nur für Instanz geändert S = 77;} //statisches Attribut, für Klasse geändert } //Zugriff von Außen: MeineKlasse.s = 40; //Zugriff auf statisches Attribut //es gibt noch keine Instanz der Klasse MeineKlasse ms1 = new MeineKlasse(); MeineKlasse ms2 = new MeineKlasse(); ms1.n = 65; // dies geht erst nach Instanz-Erzeugung ms1.s = 64; // dasselbe wie MeineKlasse.s = 64; //ms2.s ist nun ebenfalls 64

22 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0422 Beispiel für Nutzung statischer Attribute class Punkt{ static int anzahl; //statisches Attribut: Anzahl //der Instanzen Punkt(){ anzahl = anzahl + 1; }..... System.out.println(„Anzahl Punkte: „ + Punkt.anzahl); //Ausgabe: 0 Punkt p1 = new Punkt(); Punkt p2 = new Punkt(); System.out.println(„Anzahl Punkte: „ + Punkt.anzahl); //Ausgabe: 2

23 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0423 Statische Methoden die bisher behandelten Methoden (nicht-statische Methoden) –werden für eine Instanz aufgerufen –haben Zugriff auf alle Attribute der Instanz statische Methoden werden –für eine Klasse, nicht für eine Instanz aufgerufen –haben keinen Zugriff auf (nicht-statische) Attribute einer Instanz –haben Zugriff auf statische Attribute der Klasse Definition: Voranstellen von static vor der Definition: class Klassenbezeichner { static Rückgabetyp Methodenbezeichner (Parameterliste) {... } }

24 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0424 Aufruf von statischen Methoden Aufruf von nicht-statischen Methoden: –Referenzvariable.methode() –es muss Instanz der Klasse (Referenzvariable) existieren Zugriff auf statische Attribute: –Klassenname.methode() –es muss nicht unbedingt eine Instanz der Klasse existieren –falls Instanz der existiert: Referenzvariable.methode –oder innerhalb der Klasse: methode Beispiel: class MeineKlasse { static int methode(){ }.......... int i = MeineKlasse.methode();

25 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0425 MethodeStatisch() MethodeNichtStatisch() Statische Methoden: eine Klasse und Ihre Instanzen Klasse static int s = 7 int n Instanz n = 65 Instanz n = 25 Instanz n = 4 Instanz n = 76 Bauplan Zugriff

26 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0426 Bekannte Beispiele für statische Methoden public static main... –wird vom System aufgerufen, obwohl nie eine Instanz der zugehörigen Klasse erzeugt wurde Math.sin(double w) –sin ist eine Methode der Klasse Math –sin wird nicht für eine Instanz aufgerufen, sondern "einfach so": double d = Math.sin(2); –Aufruf mit vorangestelltem Klassennamen Math

27 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0427 Benachbarte Dreiecke statisch Die Methode, die ermittelt, ob zwei Dreiecke benachbart sind (Übungsaufgabe), kann alternativ als statische Methode formuliert werden: class Dreieck{....... static boolean benachbart(Dreieck d1, Dreieck d2){ int anzahlGleicherPunkte = 0; if(d1.A.abstand(d2.A) == 0 ) return true; if(d1.A.abstand(d2.B) == 0 ) return true;......... if(d1.C.abstand(d2.C) == 0 ) return true; return false; }

28 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0428 Benachbarte Dreiecke statisch: Aufruf //Aufruf: Dreieck d1 = new Dreieck(4.3,9.8,2.1, 4.3, 9.8, 2.1); Dreieck d2 = new Dreieck(5.2,2.1,4.3, 4.3, 9.8, 2.1); boolean b = Dreieck.benachbart(d1,d2); if(b) System.out.println("Dreiecke sind benachbart"); //Zum Vergleich: Aufruf mit nicht statischer Methode: boolean b = d1.benachbart(d2);

29 G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/0429 Hausaufgabe Ergänzt die Klasse "Dreieck" so, dass mit einer Methode die Summe der Umfänge aller bisher erzeugten Dreiecke ermittelt und zurückgegeben werden kann. Erzeugt drei Dreiecke und gebt die Summe der Umfänge vorher und nachher aus. Hinweis: –es bietet sich an, die Summe der Umfänge in einem statischen Attribut zu speichern


Herunterladen ppt "Institut für Kartographie und Geoinformation Prof. Dr. Lutz Plümer, Dr. Gerhard Gröger, Dipl.-Ing. D. Dörschlag Einführung in die Programmierung mit Java."

Ähnliche Präsentationen


Google-Anzeigen