2 Eine einfache Programmiersprache

Ähnliche Dokumente
4 Kontrollfluss-Diagramme

II.1.1. Erste Schritte - 1 -

6 Speicherorganisation

RO-Tutorien 3 / 6 / 12

II. Grundlagen der Programmierung. 9. Datenstrukturen. Daten zusammenfassen. In Java (Forts.): In Java:

3. Anweisungen und Kontrollstrukturen

Repetitorium Informatik (Java)

Modul Entscheidungsunterstützung in der Logistik. Einführung in die Programmierung mit C++ Übung 2

Java Einführung Methoden. Kapitel 6

Das erste Programm soll einen Text zum Bildschirm schicken. Es kann mit jedem beliebigen Texteditor erstellt werden.

1 Polymorphie (Vielgestaltigkeit)

Einführung in den Einsatz von Objekt-Orientierung mit C++ I

Vorkurs Informatik WiSe 15/16

Probeklausur: Programmierung WS04/05

Schachtelung der 2. Variante (Bedingungs-Kaskade): if (B1) A1 else if (B2) A2 else if (B3) A3 else if (B4) A4 else A

Die Programmiersprache C Eine Einführung

Java Cheatsheet. Mehrzeiliger Kommentar (beginnt mit /* und endet mit */)

Programmierung WS12/13 Lösung - Übung 1 M. Brockschmidt, F. Emmes, C. Otto, T. Ströder

Gliederung. Tutorium zur Vorlesung. Gliederung. Gliederung. 1. Gliederung der Informatik. 1. Gliederung der Informatik. 1. Gliederung der Informatik

Tutoraufgabe 1 (Zweierkomplement): Lösung: Programmierung WS16/17 Lösung - Übung 2

! 1. Unterklassen und Vererbung! 2. Abstrakte Klassen und Interfaces! 3. Modularität und Pakete! 4. Ausnahmen (Exceptions) II.4.

Java Einführung Programmcode

Java 8. Elmar Fuchs Grundlagen Programmierung. 1. Ausgabe, Oktober 2014 JAV8

JavaScript. Dies ist normales HTML. Hallo Welt! Dies ist JavaScript. Wieder normales HTML.

Einstieg in die Informatik mit Java

Programmierung mit C Zeiger

Brainfuck. 1 Brainfuck. 1.1 Brainfuck Geschichte und Umfeld. 1.2 Esoterische Programmiersprachen

Java Einführung Klassendefinitionen

Probeklausur: Programmierung WS04/05

Ausdrucksbäume in verschiedenen Darstellungen

Speicher und Adressraum

Einführung Datentypen Verzweigung Schleifen. Java Crashkurs. Kim-Manuel Klein May 4, 2015

GI Vektoren

1 Fehler-Objekte: Werfen, Fangen, Behandeln

15 Fehlerobjekte: Werfen, Fangen, Behandeln

Beispiel: Temperaturumwandlung. Imperative Programmierung. Schwerpunkte. 3. Grundlegende Sprachkonstruktionen imperativer Programme

Programmieren in Java

Tutorium Rechnerorganisation

Einstieg in die Informatik mit Java

Dr. Monika Meiler. Inhalt

Vorlesung Programmieren

Programmiersprachen Einführung in C. Unser erstes C-Programm. Unser erstes C-Programm. Unser erstes C-Programm. Unser erstes C-Programm

Übungen zur Vorlesung Einführung in die Informatik Wintersemester 2010/11

Präzedenz von Operatoren

Primitive Datentypen

Entwurf von Algorithmen - Kontrollstrukturen

JAVA-Datentypen und deren Wertebereich

Wiederholung Wozu Methoden? Methoden Schreiben Methoden Benutzen Rekursion?! Methoden. Javakurs 2012, 3. Vorlesung

1 Organisatorisches. 2 Compilezeit- und Laufzeitfehler. 3 Exceptions. 4 Try-Catch-Finally

Programmieren I. Prinzipieller Ablauf. Eigenschaften von JAVA. Source-Code Javac Bytecode. Java Virtual Machine (Java, Browser, Appletviewer)

Algorithmen und Datenstrukturen

Javakurs zu Informatik I. Henning Heitkötter

Hello World. Javakurs 2014, 1. Vorlesung. Sebastian Schuck. basierend auf der Vorlage von Arne Kappen. wiki.freitagsrunde.org. 3.

Programmieren I + II Regeln der Code-Formatierung

Einführung in die C-Programmierung

Elementare Datentypen in C++

Grundlagen der Programmierung Prof. H. Mössenböck. 6. Methoden

Objektorientierte Programmierung

Funktionen Häufig müssen bestimmte Operationen in einem Programm mehrmals ausgeführt werden. Schlechte Lösung: Gute Lösung:

Grundlagen der Programmierung Prof. H. Mössenböck. 16. Ausnahmen (Exception Handling)

Vorlesung Informatik II

Einleitung Entwicklung in C Hello-World! Konstrukte in C Zusammenfassung Literatur. Grundlagen von C. Jonas Gresens

Java Fehlerbehandlung

Einführung in die Java- Programmierung

Einführung Datentypen Verzweigung Schleifen Funktionen Dynamische Datenstrukturen. Java Crashkurs. Kim-Manuel Klein

Informatik I. Übung 2 : Programmieren in Eclipse. 5. März Daniel Hentzen

Einführung in die Informatik: Programmierung und Software-Entwicklung, WS 14/15. Kapitel 11. Fehler und Ausnahmen 1

CS1005 Objektorientierte Programmierung Bachelor of Science (Informatik)

Eine Klasse beschreibt Objekte mit gleichen Attributen und Methoden.

Eine Einführung in C-Funktionen

Propädeutikum zur Programmierung

Java Einführung VARIABLEN und DATENTYPEN Kapitel 2

Übersicht. Informatik 2 Teil 3 Anwendungsbeispiel für objektorientierte Programmierung

Die Programmiersprache C99: Zusammenfassung

1. Der Einstieg in Java. Was heißt Programmieren?

Informatik. Studiengang Chemische Technologie. Michael Roth Hochschule Darmstadt -Fachbereich Informatik- WS 2012/2013.

Informatik. Studiengang Chemische Technologie. Michael Roth WS 2012/2013. Hochschule Darmstadt -Fachbereich Informatik-

Welche Informatik-Kenntnisse bringen Sie mit?

Programmierkurs Java

Informatik B von Adrian Neumann

1 Vom Problem zum Programm

Primitive Datentypen und Felder (Arrays)

Kontrollstrukturen, Pseudocode und Modulo-Rechnung

Objektorientierte Programmierung OOP Programmieren mit Java

5.4 Klassen und Objekte

M. Graefenhan Übungen zu C. Blatt 3. Musterlösung

5 Grundlagen der Java-Syntax

Einführung in Javadoc

Einführung in die Programmierung 1

2A Basistechniken: Weitere Aufgaben

Java 7. Elmar Fuchs Grundlagen Programmierung. 1. Ausgabe, Dezember 2011 JAV7

Grundlagen. Die Komponenten eines C Programms. Das erste Programm

Grundlagen der Programmierung Prof. H. Mössenböck. 10. Klassen

2. Programmierung in C

Kapitel 3: Variablen

Transkript:

2 Eine einfache Programmiersprache Eine Programmiersprache soll Datenstrukturen anbieten Operationen auf Daten erlauben Kontrollstrukturen zur Ablaufsteuerung bereitstellen Als Beispiel betrachten wir MiniJava.

Variablen Variablen dienen zur Speicherung von Daten. Um Variablen in MiniJava zu nutzen müssen sie zunächst eingeführt, d.h. deklariert werden.

Variablen Beispiel: i n t x, result ; Diese Deklaration führt die beiden Variablen mit den Namen x und result ein. Das Schlüsselwort int besagt, dass diese Variablen ganze Zahlen ( Integers ) speichern sollen. int heißt auch Typ der Variablen x und result. Variablen können dann benutzt werden, um anzugeben, auf welche Daten Operationen angewendet werden sollen. Die Variablen in der Aufzählung sind durch Kommas, getrennt. Am Ende steht ein Semikolon ;.

Variablen Beispiel: i n t x, result ; Diese Deklaration führt die beiden Variablen mit den Namen x und result ein. Das Schlüsselwort int besagt, dass diese Variablen ganze Zahlen ( Integers ) speichern sollen. int heißt auch Typ der Variablen x und result. Variablen können dann benutzt werden, um anzugeben, auf welche Daten Operationen angewendet werden sollen. Die Variablen in der Aufzählung sind durch Kommas, getrennt. Am Ende steht ein Semikolon ;.

Variablen Beispiel: i n t x, result ; Diese Deklaration führt die beiden Variablen mit den Namen x und result ein. Das Schlüsselwort int besagt, dass diese Variablen ganze Zahlen ( Integers ) speichern sollen. int heißt auch Typ der Variablen x und result. Variablen können dann benutzt werden, um anzugeben, auf welche Daten Operationen angewendet werden sollen. Die Variablen in der Aufzählung sind durch Kommas, getrennt. Am Ende steht ein Semikolon ;.

Variablen Beispiel: i n t x, result ; Diese Deklaration führt die beiden Variablen mit den Namen x und result ein. Das Schlüsselwort int besagt, dass diese Variablen ganze Zahlen ( Integers ) speichern sollen. int heißt auch Typ der Variablen x und result. Variablen können dann benutzt werden, um anzugeben, auf welche Daten Operationen angewendet werden sollen. Die Variablen in der Aufzählung sind durch Kommas, getrennt. Am Ende steht ein Semikolon ;.

Variablen Beispiel: i n t x, result ; Diese Deklaration führt die beiden Variablen mit den Namen x und result ein. Das Schlüsselwort int besagt, dass diese Variablen ganze Zahlen ( Integers ) speichern sollen. int heißt auch Typ der Variablen x und result. Variablen können dann benutzt werden, um anzugeben, auf welche Daten Operationen angewendet werden sollen. Die Variablen in der Aufzählung sind durch Kommas, getrennt. Am Ende steht ein Semikolon ;.

Operationen Zuweisung Operationen gestatten es, Werte von Variablen zu ändern. Die wichtigste Operation ist die Zuweisung. Beispiele: x = 7; Die Variable x erhält den Wert 7. result = x; Der Wert der Variablen x wird ermittelt und der Variablen result zugewiesen. result = x + 19; Der Wert der Variablen x wird ermittelt, 19 dazu gezählt und dann das Ergebnis der Variablen result zugewiesen. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 16/143

Operationen Zuweisung Operationen gestatten es, Werte von Variablen zu ändern. Die wichtigste Operation ist die Zuweisung. Beispiele: x = 7; Die Variable x erhält den Wert 7. result = x; Der Wert der Variablen x wird ermittelt und der Variablen result zugewiesen. result = x + 19; Der Wert der Variablen x wird ermittelt, 19 dazu gezählt und dann das Ergebnis der Variablen result zugewiesen. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 16/143

Operationen Zuweisung Operationen gestatten es, Werte von Variablen zu ändern. Die wichtigste Operation ist die Zuweisung. Beispiele: x = 7; Die Variable x erhält den Wert 7. result = x; Der Wert der Variablen x wird ermittelt und der Variablen result zugewiesen. result = x + 19; Der Wert der Variablen x wird ermittelt, 19 dazu gezählt und dann das Ergebnis der Variablen result zugewiesen. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 16/143

Operationen Zuweisung Achtung: Java bezeichnet die Zuweisung mit = anstatt := (Erbschaft von C... ) Eine Zuweisung wird mit ; beendet. In der Zuweisung x = x + 1; greift das x auf der rechten Seite auf den Wert vor der Zuweisung zu. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 17/143

Operationen Input/Output MiniJava enthält Operationen um Daten (Zahlen) einlesen bzw. ausgeben zu können. Beispiele: x = read(); Liest eine Folge von Zeichen ein und interpretiert sie als ganze Zahl, deren Wert sie der Variablen x als Wert zuweist. write(42); Schreibt 42 auf die Ausgabe. write(result); Bestimmt den Wert der Variablen result und schreibt dann diesen auf die Ausgabe. write(x-14); Bestimmt den Wert der Variablen x, subtrahiert 14 und schreibt das Ergebnis auf die Ausgabe.

Operationen Input/Output MiniJava enthält Operationen um Daten (Zahlen) einlesen bzw. ausgeben zu können. Beispiele: x = read(); Liest eine Folge von Zeichen ein und interpretiert sie als ganze Zahl, deren Wert sie der Variablen x als Wert zuweist. write(42); Schreibt 42 auf die Ausgabe. write(result); Bestimmt den Wert der Variablen result und schreibt dann diesen auf die Ausgabe. write(x-14); Bestimmt den Wert der Variablen x, subtrahiert 14 und schreibt das Ergebnis auf die Ausgabe.

Operationen Input/Output MiniJava enthält Operationen um Daten (Zahlen) einlesen bzw. ausgeben zu können. Beispiele: x = read(); Liest eine Folge von Zeichen ein und interpretiert sie als ganze Zahl, deren Wert sie der Variablen x als Wert zuweist. write(42); Schreibt 42 auf die Ausgabe. write(result); Bestimmt den Wert der Variablen result und schreibt dann diesen auf die Ausgabe. write(x-14); Bestimmt den Wert der Variablen x, subtrahiert 14 und schreibt das Ergebnis auf die Ausgabe.

Operationen Input/Output MiniJava enthält Operationen um Daten (Zahlen) einlesen bzw. ausgeben zu können. Beispiele: x = read(); Liest eine Folge von Zeichen ein und interpretiert sie als ganze Zahl, deren Wert sie der Variablen x als Wert zuweist. write(42); Schreibt 42 auf die Ausgabe. write(result); Bestimmt den Wert der Variablen result und schreibt dann diesen auf die Ausgabe. write(x-14); Bestimmt den Wert der Variablen x, subtrahiert 14 und schreibt das Ergebnis auf die Ausgabe.

Operationen Input/Output Achtung: Das argument der write-operation in den Beispielen ist ein int. Um es ausgeben zu können muss es erst in eine Zeichenfolge umgewandelt werden, d.h. einen String In MiniJava können auch direkt Strings ausgegeben werden: Beispiel: write("hello World!!!"); Schreibt Hello World!!! auf die Ausgabe.

Operationen Input/Output Achtung: Das argument der write-operation in den Beispielen ist ein int. Um es ausgeben zu können muss es erst in eine Zeichenfolge umgewandelt werden, d.h. einen String In MiniJava können auch direkt Strings ausgegeben werden: Beispiel: write("hello World!!!"); Schreibt Hello World!!! auf die Ausgabe.

Kontrollstrukturen Sequenz Sequenz: 1 int x, y, result; 2 x = read(); 3 y = read(); 4 result = x + y; 5 write(result); Zu jedem Zeitpunkt wird nur eine Operation ausgeführt. Jede Operation wird genau einmal ausgeführt. Die Reihenfolge, in der die Operationen ausgeführt werden, ist die gleiche, in der sie im Programm stehen. Mit Beendigung der letzten Operation endet die Programm-Ausführung. Sequenz alleine erlaubt nur sehr einfache Programme.

Kontrollstrukturen Selektion Selektion (bedingte Auswahl): 1 int x, y, result; 2 x = read(); 3 y = read(); 4 if (x > y) 5 result = x - y; 6 else 7 result = y - x; 8 write(result); Zuerst wird die Bedingung ausgewertet Ist sie erfüllt, wird die nächste Operation ausgeführt. Ist sie nicht erfüllt, wird die nächste Operation nach dem else-zweig ausgeführt.

Kontrollstrukturen Selektion Beispiel: Statt einer einzelnen Operation können die Alternativen auch aus Statements bestehen: 1 int x; 2 x = read(); 3 if (x == 0) 4 write(0); 5 else if (x < 0) 6 write(-1); 7 else 8 write(+1);

Kontrollstrukturen Selektion Beispiel:... oder aus (geklammerten) Folgen von Operationen und Statements: 1 int x, y; 2 x = read(); 3 if (x!= 0) { 4 y = read(); 5 if (x > y) 6 write(x); 7 else 8 write(y); 9 } else 10 write(0);

Kontrollstrukturen Selektion Beispiel:... eventuell fehlt auch der else-teil: 1 int x, y; 2 x = read(); 3 if (x!= 0) { 4 y = read(); 5 if (x > y) 6 write(x); 7 else 8 write(y); 9 } Auch mit Sequenz und Selektion kann noch nicht viel berechnet werden...

Kontrollstrukturen Iteration Iteration (wiederholte Ausführung) 1 int x, y; 2 x = read(); y = read(); 3 while (x!= y) { 4 if (x < y) 5 y = y - x; 6 else 7 x = x - y; 8 } 9 write(x); Zuerst wird die Bedingung ausgewertet. Ist sie erfüllt, wird der Rumpf des while-statements ausgeführt. Nach Ausführung des Rumpfs wird das gesamte while-statement erneut ausgeführt. Ist die Bedingung nicht erfüllt fährt die Programmausführung hinter dem while-statement fort.

2 Eine einfache Programmiersprache Theorem ( Berechenbarkeitstheorie) Jede (partielle) Funktion auf ganzen Zahlen, die überhaupt berechenbar ist, läßt sich mit Selektion, Sequenz, und Iteration, d.h., mithilfe eines MiniJava-Programms berechnen. Beweisidee Was heißt berechenbar? Eine Funktion heißt berechenbar wenn man sie mithilfe einer Turingmaschine berechnen kann. Schreibe ein MiniJava-Programm, das eine Turingmaschine simuliert. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 26/143

2 Eine einfache Programmiersprache Theorem ( Berechenbarkeitstheorie) Jede (partielle) Funktion auf ganzen Zahlen, die überhaupt berechenbar ist, läßt sich mit Selektion, Sequenz, und Iteration, d.h., mithilfe eines MiniJava-Programms berechnen. Beweisidee Was heißt berechenbar? Eine Funktion heißt berechenbar wenn man sie mithilfe einer Turingmaschine berechnen kann. Schreibe ein MiniJava-Programm, das eine Turingmaschine simuliert. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 26/143

2 Eine einfache Programmiersprache MiniJava-Programme sind ausführbares Java. Man muss sie nur geeignet dekorieren. Beispiel: das GGT-Programm. 1 int x, y; 2 x = read(); 3 y = read(); 4 while (x!= y) { 5 if (x < y) 6 y = y - x; 7 else 8 x = x - y; 9 } 10 write(x);

1 public class GGT extends MiniJava { 2 public static void main (String[] args) { 3 int x, y; 4 x = read(); 5 y = read(); 6 while (x!= y) { 7 if (x < y) 8 y = y - x; 9 else 10 x = x - y; 11 } 12 write(x); 13 } // Ende der Definition von main(); 14 } // Ende der Definition der Klasse GGT; Datei "GGT.java"

Erläuterungen: Jedes Programm hat einen Namen (hier GGT) Der Name steht hinter dem Schlüsselwort class (was eine Klasse ist, was public ist lernen wir später) Der Dateiname muss zum Programmnamen passen, d.h. in diesem Fall GGT.java heißen. Das MiniJava-Programm ist der Rumpf des Hauptprogramms, d.h. der Funktion main(). Die Programmausführung eines Java-Programms startet stets mit einem Aufruf dieser Funktion main(). Die Operationen write() und read() werden in der Klasse MiniJava definiert. Durch GGT extends MiniJava machen wir diese Operationen innerhalb des GGT-Programms verfügbar.

1 import javax. swing. JOptionPane ; 2 import javax. swing. JFrame ; 3 public class MiniJava { 4 public s t a t i c i n t read ( ) { 5 JFrame f = new JFrame ( ) ; 6 String s = JOptionPane. showinputdialog ( f, " Eingabe : " ) ; 7 i n t x = 0; f. dispose ( ) ; 8 i f ( s == null ) System. exit ( 0 ) ; 9 try { x = Integer. parseint ( s. trim ( ) ) ; 10 } catch ( NumberFormatException e ) { x = read ( ) ; } 11 return x ; 12 } 13 public s t a t i c void write ( String x ) { 14 JFrame f = new JFrame ( ) ; 15 JOptionPane. showmessagedialog ( f, x, " Ausgabe", JOptionPane. PLAIN_MESSAGE ) ; 16 f. dispose ( ) ; 17 } 18 public s t a t i c void write ( i n t x ) { write ( " "+x ) ; } 19 } Datei: "MiniJava.java"

Weitere Erläuterungen: Jedes Programm sollte Kommentare enthalten, damit man sich selbst später noch darin zurecht findet! Ein Kommentar in Java hat etwa die Form: // Das i s t ein Kommentar!!! Wenn er sich über mehrere Zeilen erstrecken soll dann /* Dieser Kommentar i s t verdammt laaaaaaaaaaaang */ 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 31/143

2 Eine einfache Programmiersprache Das Programm GGT kann nun übersetzt und dann ausgeführt werden: raecke> javac GGT.java raecke> java GGT Der Compiler javac liest das Programm aus den Dateien GGT.java und MiniJava.java ein und erzeugt für sie JVM-Code, den er in den Dateien GGT.class und MiniJava.class ablegt. Das Laufzeitsystem java liest die Dateien GGT.class und MiniJava.class ein und führt sie aus. 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 32/143

Wichtige Erweiterung Arrays Arrays enthalten eine Gruppe von Variablen auf die über einen index zugegriffen wird: Deklariere Variablen a[0],...,a[99] und b[0],...,b[4]: i n t [ ] a = new i n t [100], b = new i n t [ 5 ] ; Greife auf Element a[5] zu: i n t i ; i n t [ ] a = new i n t [100]; a [ 5 ] = 1; // a [ 5 ] i s t j e t z t 1 i = 5; a [ i ] = 7; // a [ 5 ] i s t j e t z t 7 i = 7; a [ i - 2 ] = 8; // a [ 5 ] i s t j e t z t 8 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 33/143

Ausblick MiniJava ist sehr primitiv Die Programmiersprache Java bietet noch eine Fülle von Hilfsmitteln an, die das Programmieren erleichtern sollen. Insbesondere gibt es viele weitere Datentypen (nicht nur int) und viele weitere Kontrollstrukturen... kommt später in der Vorlesung! 2 Eine einfache Programmiersprache Felix Brandt, Harald Räcke 34/143