Programmieren spielend gelernt mit dem Java-Hamster-Modell Von Dietrich Boles, Oldenburg EI3 B.GTeubner Stuttgart· Leipzig 1999 Dipl.-Inform. Dietrich Boles Geboren 1963 in Altena (Westf.). Studium der Informatik von 1988 bis 1994 an der Universitat Oldenburg. Seit 1994 wiss. Mitarbeiter des Fach bereichs Informatik der Universitat Oldenburg. RegelmaBige DurchfOh rung der Vorlesung "Programmierkurs Java" mit Obungen. Arbeits schwerpunkte: Objektorientierte Softwareentwicklung, Multimedia-Syste me und Digitale Bibliotheken. Die Deutsche Bibliothek - CIP-Einheitsaufnahme Boles, Diebich: Programmieren spielend gelernt : mit dem Java-Hamster-Modell/ Dietrich Boles. - Stuttgart; Leipzig: Teubner, 1999 ISBN 978-3-519-02297-8 ISBN 978-3-322-94667-6 (eBook) DOI 10.1007/978-3-322-94667-6 Das Werk einschlieBlich aller seiner Teile ist urheberrechtlich geschOtzt. Jede Verwertung auBerhalb der engen Grenzen des Urheberrechtsgesetzes ist ohne Zustimmung des Veri ages unzulassig und strafbar. Das gilt besonders far Verviel faltigungen, Obersetzungen, Mikroverfilmungen und die Einspeicherung und Verarbeitung in elektronischen Systemen. © 1999 B.G.Teubner Stuttgart· Leipzig Einband: Peter Pfitz, Stuttgart Vorwort Programmieranfanger1 leiden haufig darunter, daB sie beim Programmieren ihre nor male Gedankenwelt verlassen und in eher technisch-orientierten Kategorien denken miissen, die ihnen von den Programmiersprachen vorgegeben werden. Gerade am Anfang stramen haufig so viele Neuigkeiten inhaltlicher und methodischer Art auf sie ein, daB sie leicht das Wesentliche der Programmierung, namlich das Lasen von Problemen, aus den Augen verlieren und sich in syntaktischen und technischen Ein zelheiten verirren. Der "Kampf" mit dem Compiler bekommt somit hahere Prioritat als der Programmentwurf an sich und kann friihzeitig zur Frustration fUhren. Das Hamster-Modell ist mit dem Ziel entwickelt worden, dieses Problem zu lasen. Mit dem Hamster-Modell wird dem Programmieranfanger ein einfaches aber machti ges Modell zur Verfiigung gestellt, mit dessen Hilfe er Grundkonzepte der Program mierung auf spielerische Art und Weise erlernen kann. Der Programmierer steuert einen virtuellen Hamster durch eine virtuelle Landschaft und laBt ihn bestimmte Aufgaben lasen. Die Anzahl der gleichzeitig zu beriicksichtigenden Konzepte wird im Hamster-Modell stark eingeschrankt und nach und nach erweitert. Mit einer ahnlichen Motivation wurde in den 70er und 80er Jahren die Schild kraten-Graphik der Programmiersprache LOGO entwickelt bzw. erprobt [Ros83, Men85]. Problem der Sprache LOGO war allerdings, daB sie sich - wenn iiber haupt - nur im Ausbildungssektor nicht aber beispielsweise im industriellen Be reich durchsetzen konnte. Dem "Mutterspracheneffekt" kommt jedoch auch beim Programmieranfanger eine wichtige Bedeutung zu: Die Muttersprache beherrscht man wesentlich besser als jede spater erlernte Sprache. Aus diesem Grund wurde fUr das Hamster-Modell keine neue Programmiersprache entwickelt. Vielmehr wurde das Modell in die Konzepte und die Syntax der Programmiersprache Java [AG96, GJS97] eingebettet. Die Sprache Java, die auch als "Sprache des Internet" bezeichnet wird, ist eine (relativ) einfache Sprache, die viele wichtige Programmierkonzepte enthalt und sich - insbesondere im Zusammenhang mit dem rapiden Wachstum des Internet - auch im industriellen Bereich immer mehr durchzusetzen beginnt. Das Hamster-Modell wurde in einer einfachen Version zu Beginn der 80er Jahre in der GMD (Gesellschaft fiir Mathematik und Datenverarbeitung) entwickelt [Opp83]. Zielsprache war damals die imperative Programmiersprache ELAN [KL83, KL85]. Vorlage fUr das Hamster-Modell war dabei "Karel der Roboter" [PRS95, BSRP97]. Ich habe das imperative Hamster-Modell an die Programmiersprache Java angepafit und um Konzepte der objektorientierten und parallelen Programmierung erweitert. lLediglich aufgrund der besseren Lesbarkeit wird in diesem Buch ausschlieBlich die maskuline Form verwendet. 4 Dabei werden nicht der gesamte Sprachschatz der Programmiersprache Java, son dern lediglich die grundlegenden Konstrukte behandelt. Dieses Werk besteht aus insgesamt vier Teilen. Teil 1 und 2 befinden sich in diesem ersten Band; die Teile 3 und 4 sind zur Zeit in Bearbeitung und werden hoffentlich im Laufe des nii.chsten James in einem zweiten Band erscheinen. Der erste Teil gibt eine allgemeine Einfiihrung in die Grundlagen der Programmierung. 1m zweiten Teil wer den die Konzepte der imperativen Programmierung vorgestellt. 1m einzelnen werden im zweiten Teil Anweisungen und Programme, Prozeduren, Kontrollstrukturen, der Top-Down-Programmentwurf, Variablen und Ausdriicke, Funktionen und Parame ter sowie das Prinzip der Rekursion behandelt. Auf den imperativen Programmier konzepten aufbauend wird im dritten Teil in die objektorientierte Programmierung eingefiihrt. Konzepte, die im dritten Teil erHi.utert werden, sind Objekte, Klassen, Arrays, Vererbungsmechanismen, Polymorphismus und dynamisches Binden sowie Zugriffsrechte. 1m dritten Teil werden die Grundlagen gelegt fiir die Vorstellung paralleler Programmierkonzepte im vierten Teil des Buches, in dem Prozesse bzw. Threads, die Inter-Prozefi-Kommunikation, die Synchronisation sowie Scheduling mechanismen behandelt werden. Beim Hamster-Modell steht nicht so sehr das "Learning-by-Listening" bzw. "Lear ning-by-Reading" im Vordergrund, sondern vielmehr das " Learning-by-Doing" . Aus diesem Grund enthalten die einzelnen Kapitel jeweils viele Beispielprogramme und Ubungsaufgaben, die Sie intensiv bearbeiten sollten. Des weiteren mochte ich den Lesern bzw. Ubenden ans Herz legen, sich selbst weitere Aufgaben auszudenken. Programmieren lernt man am beste n durch Uben, Uben, Uben. Zu diesem Buch existiert auch unter folgendem URL eine spezielle WWW-Seite: http://www-is.informatik.uni-oldenburg.de;-dibo/hamster. Auf dieser Seite finden Sie erganzende Informationen, Korrekturen, weitere Beispielprogramme, Auf gaben, Musterlosungen und vieles mehr. Uber die WWW-Seite konnen Sie auch mit mir Kontakt aufnehmen. Ich freue mich iiber jede Anregung, die zur Verbesserung des Hamster-Modells und des Buches beitragt. Fiir das Erstellen und Ausfiihren von Hamster-Programmen wurde ein spezielles Java-Programm, der sogenannte "Hamster-Simulator" entwickelt. Um das Buch mog lichst kostengiinstig anbieten zu konnen, wurde auf eine beigelegte CD-ROM mit diesem Programm verzichtet. Stattdessen steht der Hamster-Simulator auf der oben angegebenen WWW-Seite zum kostenlosen Download bereit. Sollten Sie keinen Internet-Zugang besitzen, konnen Sie den Hamster-Simulator auf CD-ROM auch gegen einen Unkostenbeitrag von 10,- DM bzw. 5,- EURO (ink!. Versandkosten) bei mir anfordern (Briefmarken oder Verrechnungsscheck beilegen). Meine Anschrift lautet: Dietrich Boles, Universitat Oldenburg, Fachbereich Informatik, Escherweg 2, D-26121 Oldenburg, email: [email protected] Ebenfalls auf der WWW-Seite befindet sich eine elektronische Version dieses Buches, die Sie sich mit Hilfe eines WWW-Browsers (Netscape-Navigator ab Version 4.0.7) 5 anschauen konnen. In diese Version ist in Form eines Java-Applets der Hamster Simulator eingebettet, iiber den Sie die im Text vorhandenen Beispielprogramme direkt ausfiihren lassen konnen. Das in diesem Buch beschriebene Java-Hamster-Modell ist bereits seit drei Jahren integraler Bestandteil des "Programmierkurs Java", der in jedem Wintersemester yom Fachbereich Informatik der Universitat Oldenburg angeboten wird. Ich mochte mich hiermit bei den Studierenden ganz herzlich fiir die zahlreichen Anregungen, Tips und Verbesserungsvorschlage bedanken. Ebenfalls Dank gebiihren Prof. Dr. Hans-Jiirgen Appelrath, fiir seine freundliche Unterstiitzung bei der Erstellung des Buches sowie Markus Siegmann und Tammo Freese fiir das sorgfiiltige Korrekturle sen. Mein besonderer Dank gilt aber Daniel Jasper fiir die mit groBem Engagement durchgefiihrte Entwicklung und Implementierung des Hamster-Simulators, Ricarda Freundl fiir die Anfertigung der mich immer wieder aufs Neue motivierenden niedli chen Hamster-Zeichnungen, die Sie durch das gesamte Buch begleiten werden, und bei meiner Lebensgefahrtin Cornelia Haber fiir die Erstellung der Syntaxdiagramme in diesem Buch und fiir ihre Geduld, wenn ich mich mal wieder ein ganzes Wochen ende mit "dem Hamster" beschaftigt habe. Hinweisen mochte ich an dieser Stelle noch auf ein erganzendes Buch: die "Start hilfe Informatik" von H.-J. Appelrath, D. Boles, V. Claus und 1. Wegener, eben falls erschienen im Teubner-Verlag. Wahrend das vorliegende "Hamster-Buch" eine Einfiihrung in die Programmierung im speziellen darstellt, hilft die Starthilfe beim Einstieg in die Informatik im allgemeinen. Ausfiihrlich behandelt werden in der Starthilfe die zentralen Begriffe "AIgorithmus" und "Datenstrukturen". Weiterhin werden dort eine Einfiihrung in die objektorientierte Softwareentwicklung und ein Uberblick iiber die Kerngebiete der Praktischen Informatik (Compilerbau, Betriebs systeme, Datenbanken, Rechnernetze) gegeben. Nun wiinsche ich aber allen Lesern viel SpaB beim "Programmieren Lernen mit dem Hamster". Oldenburg, im Mai 1999 Dietrich Boles Inhaltsverzeichnis I Grundlagen 13 .... . . . . . . . . . . . . . . 1 Programmierung 17 1.1 Ziele der Programmierung . 17 1.2 Algorithmen . 18 1.3 Programme 25 2 Programmiersprachen.................. 27 2.1 Klassifikation von Programmiersprachen . 27 2.2 Definition von Programmiersprachen . 28 2.3 Syntaxdarstellungen . . . . . . . . . . 29 3 Programmentwicklung . 35 3.1 Entwicklungsphasen .. 35 3.2 Entwicklungswerkzeuge 40 ... . . . . . . . . . . . . . . . . 4 Computer 43 4.1 Aufbau eines Computers . . .. . .. 43 4.2 Von-Neumann-Prinzipien der Rechnerarchitektur 46 4.3 Arbeitsweise eines Computers . 47 4.4 Speicher ... 48 4.5 Betriebssystem 51 4.6 Dateien und Verzeichnisse 51 4.7 Window-System .... 51 8 Inhaltsverzeichnis . . . . . . . . . . . . . . . . . . . . 5 Aussagenlogik 53 5.1 Aussagen ......... 53 5.2 Operationen auf Aussagen . 53 5.3 Syntax von Aussagen ... 54 5.4 A.quivalenz von Aussagen 55 5.5 Algebraische Eigenschaften von booleschen Operatoren . 56 II Imperative Programmierung 59 6 Grundlagen des Hamster-Modells . . . . . . . . . . . 63 6.1 Motivation ............. . 63 6.2 Komponenten des Hamster-Modells 67 6.3 Grundlagen der Hamstersprache .. 69 ............. 7 Anweisungen und Programme 73 7.1 Hamsterbefehle 73 7.2 Anweisungen 76 7.3 Programme 78 7.4 Kommentare 79 7.5 Beispielprogramme 81 7.6 Ubungsaufgaben 84 8 Prozeduren .. 87 8.1 Motivation .. 87 8.2 Prozed urdefinition 88 8.3 Prozeduraufruf 91 8.4 Programme (mit Prozeduren) 93 8.5 Vorteile von Prozeduren 96 8.6 Beispielprogramme 97 8.7 Ubungsaufgaben 101 Inhaltsverzeichnis 9 ................ 9 Auswahlanweisungen . 105 9.1 Test befehle ........ 105 9.2 Boolesche Operatoren und Ausdriicke 107 9.3 Blockanweisung . 113 9.4 Leeranweisung 115 9.5 Bedingte Anweisung 116 9.6 Alternativanweisung 120 9.7 Beispielprogramme . 123 9.8 Ubungsaufgaben .. 128 ............... 10 Wiederholungsanweisungen 131 10.1 Motivation ... 131 10.2 while-Anweisung 132 10.3 do-Anweisung .. 142 10.4 Beispielprogramme 146 10.5 Ubungsaufgaben 150 11 Boolesche Funktionen . 155 11.1 Motivation ........ . 155 11.2 Boolesche return-Anweisung . 156 11.3 Definition boolescher Funktionen 157 11.4 Aufruf boolescher Funktionen . 161 11.5 Seiteneffekte ... 166 11.6 Beispielprogramme 169 11. 7 Ubungsaufgaben . 175 10 lnhaltsverzeichnis ................. 12 Programmentwurf 179 12.1 Losen von Problemen 179 12.2 Analyse 180 12.3 Entwurf 183 12.4 Implementierung 187 12.5 Test ...... 189 12.6 Dokumentation 191 12.7 Ein wei teres Beispiel 192 12.8 Ubungsaufgaben .. 204 13 Boolesche Variablen • 207 13.1 Motivation ....... . 207 13.2 Definition boolescher Variablen 209 13.3 Nutzung boolescher Variablen . 212 13.4 Boolesche Zuweisung ..... . 214 13.5 Giiltigkeitsbereich einer booleschen Variable . 217 13.6 Lebensdauer einer booleschen Variable 224 13.7 Beispielprogramme 225 13.8 Ubungsaufgaben 229 ............ 14 Zahlen, Variablen und Ausdriicke 233 14.1 Motivation 233 14.2 Zahlen ... 234 14.3 int-Variablen 235 14.4 int-Zuweisung . 236 14.5 Arithmetische Ausdriicke 237 14.6 Vergleichsausdriicke ... 242 14.7 Verallgemeinerung von Variablen und Ausdriicken 245 14.8 Beispielprogramme 253 14.9 Ubungsaufgaben 259 Inhaltsverzeichnis 11 ............... 15 Prozeduren und Funktionen 265 15.1 int-return-Anweisung ...... 265 15.2 Definition von int-Funktionen . 266 15.3 Aufruf von int-Funktionen ... 269 15.4 Verallgemeinerung des Funktionskonzeptes . 271 15.5 Beispielprogramme 274 15.6 Ubungsaufgaben 281 16 Funktionsparameter . 285 16.1 Motivation ....... . 285 16.2 Funktionen mit Parametern 287 16.3 Uberladen von Funktionen . 296 16.4 Beispielprogramme 299 16.5 Ubungsaufgaben . 307 17 Rekursion 313 17.1 Motivation 314 17.2 Definitionen . 315 17.3 Veranschaulichung des Rekursionsprinzips 318 17.4 Rekursive Funktionen .......... . 324 17.5 Rekursive Funktionen mit lokalen Variablen . 325 17.6 Rekursive Funktionen mit Parametern 326 17.7 Backtracking . . . 327 17.8 Beispielprogramme 330 17.9 Ubungsaufgaben . 338 Literatur . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 342 Index . ..................................... 344