Dietrich Boles Programmieren spielend gelernt mit dem Java-Hamster-Modell Dietrich Boles Programmieren spielend gelernt mit dem Java-Hamster-Modell 4., überarbeitete Auflage Bibliografische Information der Deutschen Bibliothek Die Deutsche Bibliothek verzeichnet diese Publikation in der Deutschen Nationalbibliografie; detaillierte bibliografische Daten sind im Internet über <http://dnb.ddb.de> abrufbar. Dr. Dietrich Boles Geboren 1963 in Altena (Westf.). Studium der Informatik von 1988 bis 1994 an der Universität Ol- denburg. Seit 1994 wissenschaftlicher Mitarbeiter des Departments für Informatik an der Universität Oldenburg. 2002 dort Promotion. Seit 1996 zuständig für die Programmierausbildung von Informatik- Studierenden an der Universität Oldenburg. Arbeitsschwerpunkte: Objektorientierte Softwareentwicklung und eLearning. 1. Auflage 1999 2. Auflage 2002 3. Auflage 2007 4., überarbeitete Auflage 2008 Alle Rechte vorbehalten © B.G.Teubner Verlag / GWV Fachverlage GmbH, Wiesbaden 2006 Lektorat: Ulrich Sandten / Kerstin Hoffmann Der B. G. Teubner Verlag ist ein Unternehmen von Springer Science+Business Media. www.teubner.de Das Werk einschließlich aller seiner Teile ist urheberrechtlich ges chützt. Jede Verwertung außerhalb der engen Grenzen des Urh eberr echtsg esetzes ist ohne Zustimmung des Ver- lags unzuläss ig und strafb ar. Das gilt insbesondere für Vervielfältigungen, Übersetzun- gen, Mikro v er filmungen und die Eins peicher ung und Verarbeitung in elekt ron ischen Syst emen. Die Wiedergabe von Gebrauchsnamen, Handelsnamen, Warenbezeichnungen usw. in diesem Werk berechtigt auch ohne besondere Kennzeichnung nicht zu der Annahme, dass solche Namen im S inne der Warenzeichen- und Markenschutz-Gesetzgebung als frei zu betrachten wären und daher von jedermann benutzt werden dürften. Umschlaggestaltung: Ulrike Weigel, www.CorporateDesignGroup.de Buchgestaltung: Ivonne Domnick Druck und buchbinderische Verarbeitung: Strauss Offsetdruck, Mörlenbach Gedruckt auf säurefreiem und chlorfrei gebleichtem Papier. Printed in Germany ISBN 978-3-8351-0194-4 Vorwort Programmieranfänger1 leiden häufig darunter, dass sie beim Programmieren ihre normale Gedan- kenweltverlassenundinehertechnisch-orientiertenKategoriendenkenmüssen,dieihnenvonden Programmiersprachenvorgegebenwerden.GeradeamAnfangströmenhäufigsovieleNeuigkeiten inhaltlicherundmethodischerArtaufsieein,dasssieleichtdasWesentlichederProgrammierung, nämlichdasLösenvonProblemen,ausdenAugenverlierenundsichinsyntaktischenundtechni- schen Einzelheiten verirren. Der „Kampf“ mit dem Compiler bekommt somit höhere Priorität als derProgrammentwurfansichundkannfrühzeitigzurFrustrationführen. DasHamster-ModellistmitdemZielentwickeltworden,diesesProblemzulösen.MitdemHamster- ModellwirddemProgrammieranfängereineinfachesabermächtigesModellzurVerfügunggestellt, mit dessen Hilfe er Grundkonzepte der Programmierung auf spielerische Art und Weise erlernen kann.DerProgrammierersteuerteinenvirtuellenHamsterdurcheinevirtuelleLandschaftundlässt ihnbestimmteAufgabenlösen.DieAnzahldergleichzeitigzuerlernendenbzw.zuberücksichtigen- denKonzeptewirdimHamster-Modellstarkeingeschränktundnachundnacherweitert. Mit einer ähnlichen Motivation wurde in den 70er und 80er Jahren die Schildkröten-Graphik der ProgrammierspracheLOGOentwickeltbzw.erprobt[Ros83,Men85].ProblemderSpracheLOGO warallerdings,dasssiesich–wennüberhaupt–nurimAusbildungssektornichtaberbeispielswei- se im industriellen Bereich durchsetzen konnte. Dem „Mutterspracheneffekt“ kommt jedoch auch beim Programmieranfänger eine wichtige Bedeutung zu: Die Muttersprache beherrscht man we- sentlichbesseralsjedespätererlernteSprache.AusdiesemGrundwurdefürdasHamster-Modell keine neue Programmiersprache entwickelt. Vielmehr wurde das Modell in die Konzepte und die Syntax der Programmiersprache Java [GJSB05, HMG07] eingebettet. Die Sprache Java, die auch als „Sprache des Internet“ bezeichnet wird, ist eine (relativ) einfache Sprache, die viele wichtige Programmierkonzepteenthältundsich–insbesondereimZusammenhangmitdemrapidenWachs- tum des Internet – auch im industriellen Bereich in den letzten Jahren immer mehr durchgesetzt hat. DasHamster-ModellwurdeineinereinfachenVersionzuBeginnder80erJahreinderGMD(Gesell- schaft für Mathematik und Datenverarbeitung, heute Fraunhofer Gesellschaft) entwickelt [Opp83, Amb87].ZielsprachewardamalsdieimperativeProgrammierspracheELAN[KL83,KL85].Vorla- gefürdasHamster-Modellwardabei„KarelderRoboter“[PRS94,BSRP96].Ichhabedasimpera- tiveHamster-ModellandieProgrammierspracheJavaangepasstundumKonzeptederobjektorien- tiertenundparallelenProgrammierungerweitert.DabeiwerdennichtdergesamteSprachschatzder ProgrammierspracheJava,sondernlediglichdiegrundlegendenKonstruktebehandelt. Aufbau der Java-Hamster-Bücher Die„Java-Hamster-Bücher“bestehenausinsgesamtdreiBänden.DieserersteBand(„Programmie- ren spielend gelernt mit dem Java-Hamster-Modell“) gibt im ersten Teil eine allgemeine Einfüh- 1LediglichaufgrundderbesserenLesbarkeitwirdindiesemBuchausschließlichdiemaskulineFormverwendet. VI rungindieGrundlagenderProgrammierung.ImzweitenTeilwerdendieKonzeptederimperativen Programmierungvorgestellt.ImEinzelnenwerdenhierAnweisungenundProgramme,Prozeduren, Kontrollstrukturen, der Top-Down-Programmentwurf, Variablen und Ausdrücke, Funktionen und ParametersowiedasPrinzipderRekursionbehandelt. Auf den imperativen Programmierkonzepten aufbauend wird im zweiten Band der Java-Hamster- Bücher („Objektorientierte Programmierung spielend gelernt mit dem Java-Hamster-Modell“) in dieobjektorientierteProgrammierungeingeführt.DieserBandistimSeptember2004ebenfallsim Teubner-Verlag erschienen[BB04]. Konzepte, die im zweiten Band erläutert werden, sind Objek- te, Klassen, Arrays, Vererbungsmechanismen, Polymorphie und dynamisches Binden, Exceptions sowieZugriffsrechteundPakete. ImzweitenBandwerdendieGrundlagengelegtfürdieVorstellungparallelerProgrammierkonzepte imdrittenBandderJava-Hamster-Bücher.HierinwerdenunteranderemProzessebzw.Threads,die Kommunikation zwischen Prozessen, die Synchronisation, Schedulingmechanismen sowie Dead- locksbehandelt.Band3befindetsichimMomentinArbeitundwirdallerVoraussichtnachAnfang 2008 mit dem Titel „Parallele Programmierung spielend gelernt mit dem Java-Hamster-Modell“ ebenfallsimTeubner-Verlagerscheinen. Anmerkungen zur zweiten Auflage Die zweite Auflage des ersten Bandes des Java-Hamster-Buches unterscheidet sich von der ersten AuflagedurchdieAnpassungandieneuedeutscheRechtschreibungsowiedieBeseitigungeiniger kleinererFehler. Anmerkungen zur dritten Auflage Die dritte Auflage des ersten Bandes des Java-Hamster-Buches unterscheidet sich von der zwei- tenAuflagedurchdieBeseitigungeinigerTipp-FehlerundauchinhaltlicherFehler,diesichindie beiden ersten Auflagen eingeschlichen hatten. Weiterhin wurden alle Hamster-Programme an die Java-Code-Conventions angepasst, an die sich mittlerweile quasi alle Java-Programmierer halten. Hierbei handelt es sich um allgemeine Richtlinien, was die Gestaltung von Programmen und die WahlvonBezeichnernangeht.HinzugekommenistinKapitel14einAbschnitt,derdieInkrement- und Dekrement-Operatoren einführt, da diese in Java-Programmen doch relativ häufig eingesetzt werden.Kapitel16wurdefernerumeinenAbschnitterweitert,derdasvarargs-Konstruktvorstellt. HierbeihandeltessichumeinKonzept,dasabderVersion5.0indieSpracheJavaintegriertwurde underlaubt,ParameterlistenmiteinervariablenAnzahlanParameternzudefinieren.Anzumerken istandieserStelle,dassdieProgrammierspracheJavaabderVersion5.0umeinigeneueKonstrukte erweitertwurde.DiesebetreffenallerdingsmitAusnahmedesvarargs-Konstruktesalledieobjekt- orientiertenKonzeptederSpracheundsindindiesemBanddahernichtvonInteresse.MitKapitel 18 (Ausblick) wurde ein neues Kapitel ergänzt, das einen ersten Einblick in die weiterführenden Bände der Java-Hamster-Bücher gibt. Außerdem gibt es nun ein Glossar, in dem die wichtigsten Begriffe nochmal kurz definiert werden. Viele Hamster-Programmierer haben den Wunsch nach weiteren Aufgaben geäußert. Diesem Wunsch bin ich gerne nachgekommen und habe zahlreiche neueHamster-AufgabenindieeinzelnenKapitelintegriert. VII Anmerkungen zur vierten Auflage In der Hand halten Sie nun die vierte Auflage des ersten Bandes der Java-Hamster-Bücher. Auf WunschvielerLeserhabenwirinsbesondereVerbesserungenamErscheinungsbilddesBuchesvor- genommen.InhaltlichwurdeinKapitel14einAbschnitthinzugefügt,derweitereDatentypenvon Javavorstellt.EinpaarneueAufgabensindauchhinzugekommen.DieRechtschreibungwurdean dieseit1.August2006gültigenRegelnangepasst.AußerdemwurdenwiedereinpaarkleinereFeh- lerkorrigiert. Das Java-Hamster-Modell im WWW ZumJava-Hamster-ModellexistiertauchunterfolgendemURLeinespezielleWebsite:www.java- hamster-modell.de. Auf dieser Site finden Sie ergänzende Materialien, Korrekturen, weitere Bei- spielprogramme,Aufgaben,einDiskussionsforumundvielesmehr. Der Hamster-Simulator BeimHamster-Modellstehtnichtsosehrdas„Learning-by-Listening“bzw.„Learning-by-Reading“ im Vordergrund, sondern vielmehr das „Learning-by-Doing“, also das Üben. Aus diesem Grund enthaltendieeinzelnenKapitelderBücherjeweilsvieleBeispielprogrammeundÜbungsaufgaben, dieSieintensivbearbeitensollten. Um die Beispielprogramme nachvollziehen zu können und die Aufgaben nicht nur mit Stift und Papier lösen zu müssen, haben wir ein spezielles Java-Programm, den sogenannten „Hamster-Si- mulator“, entwickelt. Dieser stellt er eine Reihe von Werkzeugen zum Erstellen und Ausführen vonHamster-ProgrammenzurVerfügung:einenEditorzumEingebenundVerwaltenvonHamster- Programmen,einenCompilerzumÜbersetzenvonHamster-Programmen,einenTerritoriumsgestal- ter zum Gestalten und Verwalten von Hamster-Territorien, einen Interpreter zum Ausführen von Hamster-Programmen und einen Debugger zum Testen von Hamster-Programmen. Der Hamster- Simulatoristeinfachzubedienen,wurdeaberfunktionalundbedienungsmäßigbewusstanprofes- sionelleEntwicklungsumgebungenfürJava(z.B.Eclipse)angelehnt,umeinenspäterenUmstiegauf diesezuerleichtern. AufeinedemBuchbeigelegteCD-ROMmitdemHamster-Simulatorhabenwirverzichtet,umdas BuchmöglichstkostengünstiganbietenundimmeraktuelleVersionendesSimulatorszurVerfügung stellenzukönnen.StattdessenstehtderHamster-SimulatoraufderobenangegebenenWebsitezum kostenlosenDownloadbereit. IchkannIhnennurdringendempfehlen,sichdenHamster-SimulatorausdemWorldWideWebzu ladenundaufIhremComputerzuinstallieren.EsmachtnichtnurSpaß,denHamsterdurchseinTer- ritoriumflitzenzusehenundihnbeiseinerArbeitzubeobachten.VielmehristeszumErlernender Programmierung dringend erforderlich, sich selbstständig mit Aufgaben auseinanderzusetzen und Lösungsprogrammezuentwickelnundzutesten.AlleindurchLesenlerntmannichtProgrammie- ren! VIII Erfahrungen und Empfehlungen Das in diesem Buch beschriebene Java-Hamster-Modell ist bereits seit 1996 Jahren integraler Be- standteil des „Programmierkurs Java“, den ich in jedem Wintersemester am Department für Infor- matikderUniversitätOldenburgdurchführe(sieheauch ).Durch diedabeigewonnenenErfahrungenhatessichinkrementellweiterentwickelt.ObseinEinsatzden LernerfolgderStudierendentatsächlichverbesserthat,istzwarkaummessbar.DieMeinungenund RückmeldungenderStudierendenalsauchvielerandererNutzersindjedochfastausnahmslosposi- tiv. Dabeiseijedochanzumerken,dassdasHamster-ModellinsbesonderefürsolcheSchülerundStudie- rendengedachtist,dieProblemebeimErlernenderProgrammierunghaben.DenjenigenProgram- mieranfängern,diekeineProblemehaben,kannesdurchdiegeringeKomplexitätderAufgabennach einigerZeitlangweiligwerden.SiewollengrößereAnwendungenmitgraphischenOberflächenoder Java-Appletsentwickeln.AusdiesemGrundundderErfahrung,dassauchdieerstgenannteGruppe mal echte und nicht nur Hamster-Probleme lösen will, sollte das Java-Hamster-Modell nicht aus- schließlich, sondern motivierend und begleitend zur „richtigen“ Java-Programmierung eingesetzt werden. HinweisenmöchteichandieserStellenochaufeinergänzendesBuch:die„StarthilfeInformatik“ von H.-J. Appelrath, D. Boles, V. Claus und I. Wegener, ebenfalls erschienen im Teubner-Verlag [ABCW02].WährenddasvorliegendeJava-Hamster-BucheineEinführungindieProgrammierung imSpeziellendarstellt,hilftdieStarthilfebeimEinstiegindieInformatikimAllgemeinen.Ausführ- lichbehandeltwerdeninderStarthilfediezentralenBegriffe„Algorithmus“und„Datenstrukturen“. WeiterhinwerdendorteineEinführungindieobjektorientierteSoftwareentwicklungundeinÜber- blick über die Kerngebiete der Praktischen Informatik (Compilerbau, Betriebssysteme, Datenban- ken,Rechnernetze)gegeben. Dank Wieobenbereitserwähnt,setzeichdasJava-Hamster-ModellseitvielenJahreninmeinenVorlesun- genanderUniversitätOldenburgein.IchmöchtemichhiermitbeidenStudierendenganzherzlich fürdiezahlreichenAnregungen,TippsundVerbesserungsvorschlägebedanken.Besondersgefreut habeichmichauchüberdievielenpositivenRückmeldungenzahlreicher„Java-Hamster-Fans“,die mich in den vergangenen Jahren erreicht haben. Sie haben mir gezeigt, dass das Hamster-Modell nicht nur gut ankommt, sondern auch seinen Zweck erfüllt, Programmieranfängern die Konzepte derProgrammierungbeizubringen. Ebenfalls Dank gebührt Prof. Dr. Hans-Jürgen Appelrath für seine freundliche Unterstützung bei der Erstellung des Buches sowie meinem Lektor Ulrich Sandten vom Teubner-Verlag für die tolle Zusammenarbeit. Ein Dankeschön geht auch an Frau Ulrike Klein für ihre Unterstützung bei der optischenUmgestaltungderviertenAuflage.MeinbesondererDankgiltaberDanielJasperfürdie mitgroßemEngagementdurchgeführteEntwicklungundImplementierungdesHamster-Simulators, Ricarda Sarkar für die Anfertigung der mich immer wieder aufs Neue motivierenden niedlichen Hamster-Zeichnungen,dieSiedurchdasgesamteBuchbegleitenwerden,undbeimeinerFrau,Dr. CorneliaBoles,fürvielewichtigeHinweise,fürihretatkräftigeUnterstützungbeimKorrekturlesen, bei der Erstellung der Abbildungen und für ihre Geduld, wenn ich mich mal wieder ein ganzes Wochenendemit„demHamster“beschäftigthabe. IX Kontakt Anmerkungen,Meinungen,Lob,Kritik,FragenundVerbesserungsvorschlägezumBuchsindübri- genserwünscht.MeineAnschriftlautet:Dr.DietrichBoles,UniversitätOldenburg,Departmentfür Informatik,Escherweg2,D-26121Oldenburg;Email:[email protected] Nun wünsche ich allen Leserinnen und Lesern viel Spaß und Erfolg beim „Programmieren lernen mitdemJava-Hamster“. Oldenburg,imSeptember2007 DietrichBoles