Kein Folientitel - Institut für Geodäsie und Geoinformation der

Werbung
Institut für Kartographie und Geoinformation
Prof. Dr. Lutz Plümer, Dr. Gerhard Gröger, Dipl.-Ing. Dirk Dörschlag
Einführung in die
Programmierung mit Java
8. Vorlesung WS 2003/2004
Übersicht
• Generalisierung/ Spezialisierung
– Modellierung mittels UML (vgl. GIS I)
– Vererben von Variablen
– Vererben von Methoden
– Vererbung und Arrays
– Typkonvertierung
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
2
Hausaufgabe: Summe der Dreiecksumfänge
• 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
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
3
Besprechung: Summe der Dreiecksumfänge
class Dreieck{
....
static double summeDerUmfaenge = 0;
//Konstruktor
Dreieck(double p1x, double p1y, double p2x,...){
....
summeDerUmfaenge = summeDerUmfaenge + umfang();
}
double umfang(){...}
static double summeUmfaenge(){return summeDerUmfaenge;}
}
//Benutzung:
System.out.println(Dreieck.summeUmfaenge()); //liefert 0
Dreieck d1 = new Dreieck(1.7,6.4,5.8,4.3,6.2,9.4);
Dreieck d2 = new Dreieck(6.2,1.4,3.9,7.4,8.2,1.8);
System.out.println(Dreieck.summeUmfaenge()); //liefert Summe
//der Umfänge der Dreiecke d1 und d2
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
4
Klassenhierarchien (Generalisierung)
• konzeptueller Hintergrund:
Generalisierung  Spezialisierung
• Spezifikation in UML (Unified Modeling Language):
Unterklasse 1
(speziell)
Unterklasse 2
(speziell)
Unterklasse 3
(speziell)
Abstraktion
Oberklasse
(generell)
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
5
Beispiel zu Klassenhierarchien
Ein Student ist eine
Person
Ordentlicher
Student
Person
Dozent
Verwaltungsangestellter
spezieller
Student
Ein Dozent ist eine
Person
Gasthörer
Ein Gasthörer
ist ein Student
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
6
Klassenhierarchien in Java: Syntax
Syntax:
class Unterklasse extends Oberklasse {
...
}
Beispiel:
Datei Person.java:
class Person {
. . .
}
Datei Student.java:
class Student extends Person {
. . .
}
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
7
Klassenhierarchien in Java: Allgemeines
• Eine Klasse hat höchstens eine Oberklasse
(Einfachvererbung)
• Eine Klasse kann beliebig viele Unterklassen
besitzen
• Unterklassen können selber wieder Unterklassen
besitzen
• Die oberste Klasse in Java ist die Klasse Object
– alle Klassen sind direkt oder indirekt (wg. Transitivität)
Unterklassen von Object
– wird bei der Klassendefinition kein extends-Schlüsselwort
angegeben, so ist die neue Klasse automatisch direkte
Unterklasse von Object
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
8
Vererbung
• Konsequenz aus Spezialisierung
• Eine Unterklasse erbt alle Eigenschaften ihrer
Oberklasse:
– Eine Unterklasse erbt alle Attribute ihrer Oberklasse
– Eine Unterklasse erbt alle Methoden ihrer Oberklasse
• Vererbungsbeziehung ist transitiv
– eine Unterklasse erbt die Variablen und Methoden aller
darüber liegenden Oberklassen
• wenn C Unterklasse von B ist und B Unterklasse von A,
dann erbt C auch von A
A
B
C
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
9
Bsp. für Vererbung von Attributen & Methoden
Attribute & Methoden der Klasse
class A {
int aAtt;
void aMethode(){...}
}
aAtt
aMethode()
class B extends A {
int bAtt;
void bMethode(){...}
}
aAtt, bAtt
aMethode(), bMethode()
class C extends B {
int cAtt;
void cMethode(){...}
}
class D extends C {
int dAtt;
void dMethode(){...}
}
A
B
C
D
aAtt, bAtt, cAtt
aMethode(), bMethode(), cMethode()
aAtt, bAtt, cAtt, dAtt
aMethode(), bMethode(),
cMethode(), dMethode()
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
10
Konstruktoren bei Spezialisierung: Beispiel
• class Person{
String nachname;
Person(){nachname = "unbekannt";}
Person(String nach){nachname = nach;}
}
class Student extends Person{
long matnr;
Student() {nachname = "unbekannt"; matnr = -999;}
Student(String nach, long matr){
nachname = nach; matrikelnr = matr;}
}
• Problem: Konstruktoren der Unterklasse wiederholen Befehle der
Konstruktoren der Oberklasse
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
11
Konstruktoren bei Spezialisierung: Beispiel
• class Person{
String nachname;
Person(){nachname = "unbekannt";}
Person(String nach){nachname = nach;}
}
class Student extends Person{
long matnr;
Student() {nachname = "unbekannt"; matnr = -999;}
Student(String nach, long matr){
nachname = nach; matrikelnr = matr;}
}
• Bessere Lösung: Konstruktoren der Unterklasse rufen Konstruktoren der
Oberklasse auf
• Verwendung der Methode super()
• Der super()-Aufruf muss im Konstruktor immer die erste Anweisung
sein und darf maximal einmal je Konstruktor benutzt werden
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
12
Konstruktoren: Beispiel mit Methode super
• class Person{
String nachname;
Person(){nachname = "unbekannt";}
Person(String nach){nachname = nach;}
}
class Student extends Person{
ruft Person() auf
long matnr;
Student() {super(); matnr = -999;}
Student(String nach, long matr){
super(nach); matrikelnr = matr;}
}
ruft Person(nach) auf
• super(....) ruft den Konstruktor der Oberklasse auf,
der dieselbe Anzahl/Typ von Parametern hat.
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
13
Übung im GIS-Labor
• Implementiert die Klassen Person, Student und
Mitarbeiter mit entsprechenden Konstruktoren, wobei
Person Oberklasse der beiden anderen Klassen ist:
– Personen haben als Attribute:
• Vor- und Nachname
– Studenten haben zusätzlich:
• Matrikelnummer
• Studiengang
– Mitarbeiter haben zusätzlich
• Namen des Instituts
• zur Erinnerung: class Unter extends Ober { ... }
• Der super()-Aufruf muss im Konstruktor immer die
erste Anweisung sein und darf maximal einmal je
Konstruktor benutzt werden
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
14
Typkompatibilität I
• Referenzvariablen gehören zu Klassen und Objekte
gehören zu Klassen
• Frage: Welche Objekte dürfen welchen
Referenzvariablen zugewiesen werden?
• Antwort: Einer Referenzvariablen der Klasse K dürfen
Objekte der Klasse K sowie aller Unterklassen von K
zugewiesen werden.
• Beispiel:
Student s = new Student();
Person p = s;
//OK, da Person Oberklasse von
//Student ist
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
15
Typkompatibilität II
• Der umgekehrte Weg geht nicht:
– Einer Variablen der Unterklasse K kann kein Objekt ihrer
Oberklasse zugewiesen werden (dem Objekt fehlen die für die
Unterklasse spezifischen Eigenschaften)
• Beispiel 1:
Person p = new Person();
Student s = p; //geht nicht, da nicht jede Person
//ein Student ist
• Beispiel 2:
Student s1 = new Student();
Person p = s1; //s1 wird als Person angesehen
Student s2 = p; //geht nicht, da nicht jede Person
//ein Student ist
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
16
Typkompatibilität: Zulässige Attribute/Methoden
• Welche Attribute/Methoden können verwendet werden?
• Es können nur die Attribute/Methoden der Klasse der
Referenzvariablen verwendet werden, nicht die der Klasse
des Objekts
• Beispiel:
Student s = new Student();
Person p = s; //Student p wird als Person angesehen
p.nachname = "Schmitz"; //OK, da nachname Attribut
//von Person ist
p.matrikelnr = 123456; //geht nicht, da matrikelnr
//kein Attribut von Person
//ist
– p zeigt zwar auf ein Objekt der Klasse Student (mit matrikelnr),
dieses Objekt wird jedoch wie eine Person behandelt. Personen
haben i. Allg. keine matrikelnr.
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
17
Vererbung und Arrayelemente: Beispiel
• Für die Verwaltung des Hochschulsports sollen Studenten, Mitarbeiter
und Externe in einem Array gespeichert werden.
• Welchen Elementtyp hat das Array?
• 1. Ansatz: Elementtyp Object:
Object [] hsspArray = new Object[200];
hsspArray[0] = new Student("Schmitz");
hsspArray[1] = new Mitarbeiter("Meyer");
hsspArray[2] = new Person("Schulz");
//Durchsuchen nach Person namens "Schulz":
for(int i = 0 ; i < 3 ; i = i + 1)
if( hsspArray[i].name.equals("Schulz"))... //geht nicht
• Problem I: Object hat kein Attribut "name"
• Problem II: in Array kann alles (jede Unterklasse von Object)
hereingesteckt werden
• Klasse zu allgemein
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
18
Exkurs: Gleichheit von Strings
• Beispiel:
String a = "Abc";
String b = "Abc";
if( a == b ) ....
// a == b muss nicht gelten (hängt
// von Compiler/Interpreter ab)
• Problem: "==" überprüft Gleichheit der Referenz (des
String-Objekts), nicht des Werts (der Zeichenkette)
• Besser: Methode equals von String:
if( a.equals(b) ) // wahr, wenn beide Zeichenketten
// gleich sind
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
19
Vererbung und Arrayelemente: Beispiel
• Für die Verwaltung des Hochschulsports sollen Studenten, Mitarbeiter
und Externe in einem Array gespeichert werden.
• Welchen Elementtyp hat das Array?
• 2. Ansatz: Elementtyp Student
Student [] hsspArray = new Student[200];
hsspArray[0] = new Student("Schmitz");
hsspArray[1] = new Mitarbeiter("Meyer"); //geht nicht
• Problem: ein Mitarbeiter ist kein Student
• Klasse zu speziell
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
20
Vererbung und Arrayelemente: Beispiel
• Für die Verwaltung des Hochschulsports sollen Studenten, Mitarbeiter
und Externe in einem Array gespeichert werden.
• Welchen Elementtyp hat das Array?
• 3. Ansatz: Elementtyp Person:
Person [] hsspArray = new Person[200];
hsspArray[0] = new Student("Schmitz");
hsspArray[1] = new Mitarbeiter("Meyer");
hsspArray[2] = new Person("Schulz");
//Durchsuchen nach Person namens "Schulz":
for(int i = 0 ; i < 3 ; i = i + 1)
if( hsspArray[i].name.equals("Schulz")) ... //OK
• Person hat Attribut "name"
• Funktioniert dank Vererbung (Mitarbeiter und Student sind Unterklasse
von Person)
• Auch Mitarbeiter und Student werden als Person angesehen
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
21
Typkonvertierung zwischen Klassen
• Beispiel: In dem Hochschulsportarray (Elementtyp: Person) soll der
Student mit der Matrikelnummer 1234 gesucht werden
• Problem: Personen haben keine Matrikelnummer
• Lösung: Typkonvertierung von Person zu Student:
Person [] hsspArray = new Person[200];
.......
Student s = (Student) hsspArray[i];
if( s.matrikelnr == 1234 ) ...}
• Vgl. Typkonvertierung von double zu int in Vorlesung 2
• Vorsicht: Typkonvertierung ist nur erlaubt, wenn Referenzvariable
(hsspArray[i])tatsächlich auf ein Objekt vom Typ Student (oder
einer Unterklasse von Student) verweist
• Wie ermittelt man, ob ein Objekt zu einer bestimmten Klasse
gehört?
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
22
Ermittlung der Klassenzugehörigkeit
• Wie ermittelt man, ob ein Objekt zu einer bestimmten Klasse
gehört?
• boolescher Operator instanceof
• Syntax: referenzvariable instanceof Klassenname
• liefert true, wenn referenzvariable auf ein Objekt der Object
Klasse Klassenname oder einer Unterklasse von
Klassenname verweist
• Beispiel (Student Unterklasse von Person):
Person
Person p = new Person();
Student s = new Student();
Student
Object o = p;
if( o instanceof Person ) ... //liefert true
if( o instanceof Student ) ... //liefert false
o = s;
if( o instanceof Person ) ... //liefert true
if( o instanceof Student ) ... //liefert true
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
23
Bsp: Suchen nach Matrikelnummer
• Beispiel: In dem Hochulsportarray (Elementtyp: Person) soll der
Student mit der Matrikelnummer 1234 gesucht werden
Person [] hsspArray = new Person[200];
hsspArray[0] = new Student("Schmitz");
hsspArray[1] = new Mitarbeiter("Meyer");
hsspArray[2] = new Person("Schulz");
....................
//Durchsuchen nach Student mit Matrikelnr 1234
for(int i = 0 ; i < hsspArray.length ; i = i + 1)
{
if( hsspArray[i] instanceof Student)
{
Student s = (Student) hsspArray[i]; //Typkonvert.
if( s.matrikelnr == 1234 ) ....
}
}
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
24
Übungsaufgabe
• Schreibt ein Programm, das in dem
Hochschulsportarray (Elementtyp: Person) die Anzahl
der Studenten ermittelt.
• Hinweise:
– Person [] hsspArray = new Person[200];
– hsspArray[0] = new Student("Schmitz");
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
25
Hausaufgabe
• Ergänzt die vorgestellten Klassen „Person“, „Student“
und "Mitarbeiter" um die Klasse „Dozent“
(Unterklassen von Person). Die Unterklasse „Dozent“
soll dabei noch weiter in „Professor“ und „Assistent“
unterschieden werden.
• Erzeugt ein Objekt jeder Klasse und initialisiert dieses
mit Beispieldaten.
• Erzeugt ein Array, das Professoren und Assistenten
speichert. Füllt dieses mit einigen Objekten.
G. Gröger - Einführung in die Programmierung mit Java - 1. Semester - WS 03/04
26
Herunterladen