Einführung in die objektorientierte Programmierung: Unterschied zwischen den Versionen
K (→Algorithmus) |
(Algorithmus erweitert) |
||
Zeile 55: | Zeile 55: | ||
{{Definition|Ein Algorithmus ist eine Rechenvorschrift bei der in endlich vielen Schritten eine Aufgabe mit ausführbaren Anweisungen gelöst wird.}} | {{Definition|Ein Algorithmus ist eine Rechenvorschrift bei der in endlich vielen Schritten eine Aufgabe mit ausführbaren Anweisungen gelöst wird.}} | ||
− | Im Alltag eines Schülers ist der Tagesbeginn mit einem Algorithmus zu vergleichen. | + | Im Alltag eines Schülers ist der Tagesbeginn mit einem Algorithmus zu vergleichen. Vom Aufstehen bis zum Erreichen der Schule ist das eine feste Vorschrift, die täglich durchgeführt wird:<br /> |
1. Der Wecker klingelt.<br /> | 1. Der Wecker klingelt.<br /> | ||
2. Der Wecker wird ausgeschalten und das Licht angeschaltet.<br /> | 2. Der Wecker wird ausgeschalten und das Licht angeschaltet.<br /> | ||
3. Das Frühstück wird vorbereitet und anschießend gegessen.<br /> | 3. Das Frühstück wird vorbereitet und anschießend gegessen.<br /> | ||
4. Im Bad Zähne putzen.<br /> | 4. Im Bad Zähne putzen.<br /> | ||
− | 5. Die Wohnung | + | 5. Die Wohnung verlassen und per Bus/Bahn/Auto zur Schule fahren.<br /> |
− | 6. Schule ist erreicht.<br /><br /> | + | 6. Die Schule ist erreicht.<br /><br /> |
'''Arbeitsauftrag''' | '''Arbeitsauftrag''' | ||
Zeile 71: | Zeile 71: | ||
</div> | </div> | ||
<div align="right">Exkurs: [[Diagramme]]</div> | <div align="right">Exkurs: [[Diagramme]]</div> | ||
+ | |||
+ | In beiden Algorithmen gibt es Aktionen bzw. Tätigkeiten, die der Schüler s ausführt (mit s wollen wir in Zukunft die Klasse Schüler vom Objekt "Schüler" bezeichnen). Eine Aktion, die ein Objekt besitzt, wird '''Methode''' genannt. Alle Methoden, die zu einem Objekt gehören, sind in der Objektkarte eingetragen.<br /> | ||
+ | |||
+ | Für den Schüler ergeben sich somit z.B. die Methoden s.weckerAusschalten(), s.frühstücken(), s. zähnePutzen() und s.bahnFahren(). Sie werden wie in der Grafik notiert. | ||
+ | [[Bild:Krüger_Schüler.png|center]] | ||
+ | |||
+ | '''Arbeitsauftrag''' | ||
+ | {{Aufgabe|In der Objektkarte von Michael Schumacher fehlen noch passende Methoden für ein Rennauto. Erstelle dir selbst eine Objektkarte "Rennauto" und ergänze fehlende sinnvolle Attribute mit Attributwerten sowie mindestens 3 Methoden!<br /> | ||
+ | Notiere sie auf deinem Laufzettel!\}} | ||
=== Datentyp === | === Datentyp === |
Version vom 13. Januar 2010, 16:04 Uhr
Inhaltsverzeichnis |
Grundbegriffe der Programmierung
Was kennst du schon? Wo brauchst du noch Hilfe?
Bei vielen Fragen gibt es einen Button, der dir für die Lösung weiterhelfen kann. Nutze ihn nur dann, wenn du keine Antwort auf die Frage hast.
Ingenieure und Entwickler strukturieren sich ihre Aufgaben in dem sie die Informationen aus einer objektorientierten Sichtweise betrachten. Dabei fassen sie alle Dinge, die in der realen Welt existieren, als Objekte auf, um ihre Problemstellung zu bewältigen. Wie wir später sehen werden, lassen sie ihre Objekte für sich arbeiten, indem sie ihnen ein bestimmtes Verhalten programmieren.
Objekte
Definition
Objekte sind Dinge, Lebewesen oder Sachverhalte in der uns umgebenden realen oder auch virtuellen Welt. Gleichartige Objekte werden unter einem Begriff zusammengefasst (siehe nächsten Absatz).
Nehmen wir uns ein Beispiel: das Rennauto von Michael Schumacher aus seiner Weltmeistersaison 2004. Das Objekt hat verschiedene Attribute mit jeweiligen Attributwerten. In der ersten Zeile steht der Objektname, getrennt durch eine horizontale Linie folgen die Attribute mit ihren Attributwerten.
Arbeitsauftrag
Betrachten wir die geometrischen Körper Quader und Würfel. Jeder Körper baut sich aus 6 Flächen zusammen.
Wir erstellen uns ein Objekt "Fläche" mit zwei Attributen: Länge und Breite. Beide Attribute können verschiedene Werte annehmen.
Gibt es eine Möglichkeit aus 6 Objekten "Fläche" den Körper ...
... Würfel zu bauen, egal welche Werte die Attribute haben? (!ja) (nein)
... Würfel zu bauen, wenn alle Flächen gleich sind? (!ja ) (nein)
... Quader zu bauen, wenn gilt: 2 Flächen mit Länge = Breite = 4 cm, 4 Flächen mit Länge = 6 cm und Breite = 4 cm? (ja) (!nein)
Klasse
Sicherlich hast du in deinem Biologieunterricht verschiedene Tierarten behandelt. Genauso wie in der Tierwelt, werden in der Informatik Dinge mit gleicher Eigenschaft zu einer Klasse zusammengefasst. Wir können auch sagen, dass es das Grundgerüst eines (realen) Objektes ist. Dieses Grundgerüst gibt uns, wie bei den Objekten, bereits einige Attributfelder vor, die wir nun mit bestimmten Werten besetzen können. Mit dem Beispiel von Michael Schumacher wollen wir uns folgenden Unterschied klarmachen:
Jedes Rennauto ist auch ein Auto, aber nicht jedes Auto ist ein Rennauto. Nehmen wir an, dass die Klasse "Auto" schon existiert. Sie enthält schon Attribute , wie Baujahr, PS und Farbe. Andere Attribute, wie den Rennstall, müssen wir der Klasse "Auto" selbst hinzufügen.
Beachte in der nächsten Aufgabe, dass es noch Unterklassen gibt, wo der Begriff besser zuzuordnen ist.
Arbeitsauftrag
Ordne die Klassen unten den richtigen Oberklassen zu.
Klasse: Tierarten | Einzeller | Vögel | Säugetiere | Wirbellose Tier |
Klasse: Säugetiere | Delfine | Raubtiere | Paarhufer | |
Klasse: Insekt | Ameisen | Flöhe | Hornissen | Schmetterlinge |
Klasse: Nagetiere | Biber | Eichhörnchen | Murmeltier |
Bis jetzt haben wir uns nur mit den Objekten und Klassen beschäftigt. Um mit ihnen zu arbeiten, brauchen wir noch ein paar weitere Grundbegriffe aus der Informatik.
Algorithmus
Les dir zuerst die Defintion des Begriffes durch, bevor du dir das Beispiel zum besseren Verständnis anschaust.
Definition
Ein Algorithmus ist eine Rechenvorschrift bei der in endlich vielen Schritten eine Aufgabe mit ausführbaren Anweisungen gelöst wird.
Im Alltag eines Schülers ist der Tagesbeginn mit einem Algorithmus zu vergleichen. Vom Aufstehen bis zum Erreichen der Schule ist das eine feste Vorschrift, die täglich durchgeführt wird:
1. Der Wecker klingelt.
2. Der Wecker wird ausgeschalten und das Licht angeschaltet.
3. Das Frühstück wird vorbereitet und anschießend gegessen.
4. Im Bad Zähne putzen.
5. Die Wohnung verlassen und per Bus/Bahn/Auto zur Schule fahren.
6. Die Schule ist erreicht.
Arbeitsauftrag
Die Konstruktion einer Mittelsenkrechten zwischen den Punkten A und B kann als Algorithmus aufgefasst werden. Sortiere die Schritte in der richtigen Reihenfolge ein.
1. Schritt: Punkte A und B verbinden
2. Schritt: Kreise um A und B mit passendem Radius
3. Schritt: Schnittpunkte der Kreise verbinden
In beiden Algorithmen gibt es Aktionen bzw. Tätigkeiten, die der Schüler s ausführt (mit s wollen wir in Zukunft die Klasse Schüler vom Objekt "Schüler" bezeichnen). Eine Aktion, die ein Objekt besitzt, wird Methode genannt. Alle Methoden, die zu einem Objekt gehören, sind in der Objektkarte eingetragen.
Für den Schüler ergeben sich somit z.B. die Methoden s.weckerAusschalten(), s.frühstücken(), s. zähnePutzen() und s.bahnFahren(). Sie werden wie in der Grafik notiert.
Arbeitsauftrag
In der Objektkarte von Michael Schumacher fehlen noch passende Methoden für ein Rennauto. Erstelle dir selbst eine Objektkarte "Rennauto" und ergänze fehlende sinnvolle Attribute mit Attributwerten sowie mindestens 3 Methoden! |