Allgemeines
News
10.10.2014 — Studenten können den Status ihrer eingereichten Übungen online überprüfen.
29.09.2014 — Der edX MOOC ist hier!
24.09.2014 — Der MOOC ist hier!
22.09.2014 — Die Übungsgruppen wurden zusammengestellt. Wenn du deine Legi-Nummer in keiner Gruppe findest, kontaktiere bitte Georgiana und gib die bevorzugte Stufe und Sprache an.
17.09.2014 — Bitte füllen Sie den Fragebogen bis Freitag Mittag (19. September) aus um in eine Übungsgruppe eingeteilt zu werden.
24.08.2014 — Die erste Lektion findet am Dienstag, den 16. September, statt. Es gibt keine Übungstunden in der ersten Woche.
Kursbeschreibung
252-0021-00 Einführung in die Programmierung
Inhalt der Vorlesung
- Grundlagen der objekt-orientierten Programmierung
- Objekte und Klassen
- Konzept der Schnittstellen von Klassen
- Vor- und Nachbedingungen, Invarianten, Design by Contract
- Elementare Kontrollstrukturen
- Zuweisungen und Referenzierung
- Grundbegriffe aus der Hardware
- Elementare Datenstrukturen und Algorithmen
- Rekursion
- Vererbung und "deferred classes"
- Einführung in Event-driven Design und Concurrent Programming
- Grundkonzepte aus Software Engineering wie dem Softwareprozess, Spezifikation und Dokumentation, Reuse und Quality Assurance
Unterlagen
Bertrand Meyer: Touch of Class, Learning to Program Well with Objects and Contracts, Springer 2009, ISBN: 978-3-540-92144-8. Elektronische Version (Nur innerhalb des ETH Netzwerks verfügbar)
Helfen und Hilfe bekommen
Um mit der Traffic Software zu starten, könnte es helfen diese Einführung zu lesen. Wenn du einen Fehler in Traffic entdeckst, besprich das mit einem Assistenten und melde es dann als Fehlerbericht.
Falls du einen Absturz in der EiffelStudio Programmierumgebung hast, klicke bitte den "Submit bug report" Knopf und benutze den Login ethinfo1 mit Passwort ethinfo1.
Auf dem Hilfe-Forum können inhaltliche Fragen, die sich auf die Vorlesung oder Übungen beziehen, gestellt werden. Die Assistenten werden bemüht sein, diese so schnell wie möglich zu beantworten.
Downloads
Die genauen Angaben, welche Software benötigt wird und wie man diese installiert, befinden sich auf dem ersten Übungsblatt. Es ist auch möglich öffentliche Computerräume (CAB H56 und H57) zu benutzen, in welchen die nötige Software bereits installiert ist.
Zusätzliche Materialien:
- Troubleshooting (bekannte Probleme mit der EiffelStudio Installation)
- Übersetzungsliste (Vorlesungsterminologie auf Deutsch und Englisch)
- Do it with style (Übersicht über die Stilregeln von Eiffel)
- Einführung in Eiffel
Weiterführende Literatur
- Bertrand Meyer: Object-Oriented Software Construction, Second Edition, Prentice Hall, ISBN 0-13-629155-4
- Pete Thomas, Ray Weedon: Object-Oriented Programming in Eiffel, Second Edition, Addison-Wesley Eiffel in Practice Series, ISBN 0-201-33131-4
- Frieder Monninger: Eiffel. Objektorientiertes Programmieren in der Praxis, H. Heise Verlag, Hannover, ISBN 3-882-29028-5
- Bertrand Meyer: La produzione del software object oriented. Prentice Hall International, Hemel Hempstead, ISBN 88-256-0205-7
- Giuseppe Callegarin: Nuovo corso di informatica. Basi di dati e sistemi informativi. Per le Scuole superiori. CEDAM, ISBN 8-813-19565-6
- David Parnas hat das Konzept "Information Hiding" erstmals dokumentiert.
- das Software-Problem mit der Patriot Rakete.
Vorlesung
Stundenplan
Tag | Zeit | Ort |
---|---|---|
Montag | 13:00-15:00 | HG E7 |
Dienstag | 8:00-10:00 | HG E7 |
Vorlesungsfolien und Video-Aufnahmen
Video-Aufnahmen aus dem Jahr 2009 auf Englisch anschauen.
Hinweis: in den PDF-Dateien sind die verwendeten Animationen nicht enthalten, deshalb könnten einzelne Slides schwierig zu verstehen sein.
Datum | Vorlesung | Titel | Folien | Lesematerial |
---|---|---|---|---|
Di. 16.09 | 1.2 | Einführung | pdf pptx | Kapitel 1, 2 |
Mo. 22.09 | 2.1 | Handhabung von Objekten I | pdf pptx | Kapitel 2 |
Di. 23.09 | 2.2 | Handhabung von Objekten II | pdf pptx | Kapitel 3 |
Mo. 29.09 | 3.1 | Handhabung von Objekten III | pdf pptx | Kapitel 3 |
Di.30.09 | 3.2 | Die Schnittstelle einer Klasse | pdf pptx | Kapitel 4 |
Mo. 6.10 | 4.1 | Objekterzeugung | pdf pptx | Kapitel 6 |
Di. 7.10 | 4.2 | Objekterzeugung II | pdf pptx | Kapitel 6 |
Mo. 13.10 | 5.1 | Objekterzeugung III | pdf pptx | Kapitel 6 |
Di. 14.10 | 5.2 | Invarianten und Logik | pdf pptx | Kapitel 5 |
Mo. 20.10 | 6.1 | Beschreibung von Syntax | pdf pptx | Kapitel 11 |
Di. 21.10 | 6.2 | Zuweisung, Referenzen, und die Objektstruktur | pdf pptx | Kapitel 9 |
Mo. 27.10 | 7.1 | Steuerstrukturen I | pdf pptx | Kapitel 7 |
Di. 28.10 | 7.2 | Steuerstrukturen II | pdf pptx | Kapitel 7 |
Mo. 3.11 | 8.1 | Abstraktion | pdf pptx | Kapitel 8 |
Di. 4.11 | 8.2 | Das dynamische Modell | pdf pptx | Kapitel 8 |
Mo. 10.11 | 9.1 | Vererbung und generische Klassen I | pdf pptx | Kapitel 16 |
Di. 11.11 | 9.2 | Vererbung und generische Klassen II | pdf pptx | Kapitel 16 |
Mo. 17.11 | 10.1 | Rekursion I | pdf pptx | Kapitel 14 |
Di. 18.11 | 10.2 | Rekursion II | pdf pptx | Kapitel 14 |
Mo. 24.11 | 11.1 | Daten Strukturen I | pdf pptx | Kapitel 13 |
Di. 25.11. | 11.2 | Daten Strukturen II | pdf pptx | Kapitel 13 |
Mo. 1.12 | 12.1 | Mehrfachvererbung | pdf pptx | Kapitel 16 |
Di. 2.12 | 12.2 | Ein Beispiel: Undo/Redo | pdf pptx | Kapitel 17 |
Mo. 8.12 | 13.1 | Topologisches Sortieren | pdf pptx | Kapitel 15 |
Di. 9.12 | 13.2 | Ereignisbasierte Programmierung und Agenten | pdf pptx | Kapitel 17, 18 |
Mo. 15.12 | 14.1 | Inheritance complements | pdf pptx | Kapitel 14, 18 |
Di. 16.12 | 14.2 | Vom Programmieren zum Software Engineering | pdf pptx | Kapitel 19 |
= Temporäre Version = Endgültige Version
Übungen
Übungsgruppen
Hier findest du die Einteilung in die Übungsgruppen sowie die allgemeinen Informationen über die Gruppen.
Die Einteilung der Studenten in die Übungsgruppen basiert auf einer Selbsteinschätzung. Die Studenten werden dann anhand ihrer Erfahrung eingeteilt.
Übungsblätter
Die wöchentlichen Übungen werden jeden Montag vor 18:00 publiziert. Du musst deine Lösung innerhalb der nächsten neun Tage (bis Mittwoch Abend) abgeben. Der vorgeschlagene Ablauf für die Abgabe ist, die Übungen per Email zu schicken. Sie werden überprüft, aber nicht bewertet. Die Musterlösung einer Übung wird nach dem Abgabedatum (Donnerstags) hier publiziert. Studenten wird empfohlen, die Musterlösung anzuschauen und bei Unklarheiten nachzufragen.
Während des Semesters werden in den Übungsstunden zwei Probeklausuren durchgeführt. Die Probeklausuren werden überprüft und benotet an die Studenten zurückgegeben.
Woche | Übung | Links |
---|---|---|
Woche 1 | Getting started | Übungsblatt |
Woche 2 | Give me your feature name and I'll call you | Übungsblatt Lösung |
Woche 3 | Of objects and features | Übungsblatt Lösung |
Woche 4 | Object creation and logic | Übungsblatt Lösung |
Woche 5 | Assignments and control structures | Übungsblatt Lösung |
Woche 6 | Loopy games | Übungsblatt Lösung |
Woche 7 | Probeklausur 1 | Probeklausur Lösung |
Woche 8 | Inheritance and Polymorphism | Übungsblatt Lösung |
Woche 9 | Recursion | Übungsblatt Lösung |
Woche 10 | Data structures | Übungsblatt Lösung |
Woche 11 | Probeklausur 2 | Probeklausur Lösung |
Woche 12 | Agents and board games | Übungsblatt Lösung |
Folien der Übungsstunden
Datum | Material (PDF/code) | Material (PowerPoint/code) |
---|---|---|
24.09 | ppt | |
1.10 | ppt/role play game source | |
8.10 | ppt | |
15.10 | ppt | |
22.10 | ppt | |
29.10 | ppt | |
12.11 | ppt | |
19.11 | ppt/binary search tree source | |
26.11 | in-class exercise | in-class exercise 2 |
10.12 | ppt | |
17.12 | ppt |
Zusätzliche Themen | Material (PDF) | Material (PowerPoint) | Material (Anderes) |
---|---|---|---|
Syntax comparison Eiffel/Java | pptx | ||
Invariants / Marriage example | pptx | code | |
Once routines | pptx | code | |
Void safety | pptx | code | |
Programming paradigms | pptx | ||
CAT calls | pptx | ||
Verification | pptx | ||
Beyond Eiffel | pptx |