|
|||||||||||||||||||||||||||||||||||||||||||||
2. Abend |
|||||||||||||||||||||||||||||||||||||||||||||
Ziele : Wir werden nach diesem Abend in der Lage sein selbstständig ein kleines C++-Programm zu schreiben. Wir können einfache Daten zwischenspeichern und den Begriff der Variablen kennenlernen. Wir können Daten von der Tastatur in Variablen einlesen.
|
|||||||||||||||||||||||||||||||||||||||||||||
Programm erstellen |
|||||||||||||||||||||||||||||||||||||||||||||
Am ersten Abend haben wir bereits ein einfaches Programm "Hello World" erstellt. Wir haben den Programmcode mit dem Editor erstellt. Der Editor erlaubt es uns Text zu editieren, wobei gewisse Editoren in der Lage sind C++ Code speziell einzufärben ! Im Grunde genommen genügt aber ein einfacher Editor wie der Notepad um C++ Quellcode zu erstellen. Hier also ein wenig Code (zur Entspannung). |
|||||||||||||||||||||||||||||||||||||||||||||
#include <iostream> |
|||||||||||||||||||||||||||||||||||||||||||||
Diese Datei ist wie gesagt eine einfache Textdatei. Wir machen sie ein wenig aussergewöhnlich, indem wir ihr die Endung ".cpp" geben ! Diese Quellcodedatei übergeben wir jetzt dem C++-Compiler. Wie das mit der Entwicklungsumgebung, die wir verwenden funktioniert, könnt Ihr auch noch einmal nachlesen. |
|||||||||||||||||||||||||||||||||||||||||||||
Der Compiler hat nun die Aufgabe die Header Datei <iostream> einzubinden. Im Detail ist das der Präprozessor, der einfach den Inhalt der Datei die nach #include angegeben wird, in die Datei "hineinkopiert". Durch das Einbinden der iostream-Datei haben wir die Möglichkeit "cout" zu verwenden. cout ist die Kurzform für "console output". Wir schieben mit den << Zeichen den Text "Ich habe Hunger" in den Ausgabestrom (output stream). Text, der für die Ausgabe bestimmt ist, wird in Anführungszeichen gesetzt, so versucht der Compiler die Zeichen zu compilieren. Mit den Anführungszeichen behandelt der Compiler den Text als Text in unserem Sinne. |
|||||||||||||||||||||||||||||||||||||||||||||
Das Compilieren erzeugt eine sogenannte Objekt-Datei (häufig mit der Endung .obj). Diese Datei enthält bereits den Anweisungen die der Prozessor des Computers ausführen könnte. Gewisse Dinge, die wir verwenden sind aber in Bibliotheken enthalten. Zusätzlich muss ein ausführbares Programm gewisse Dinge enthalten. Die Aufgabe unser Programm fertig zusammenzubauen, das heisst mit den Bibliotheken zu verbinden und eine ausführbare Datei (.exe unter Windows) zu erstellen übernimmt der Linker. Betrachtet hierzu auch die Abbildung auf Seite 26 in unserem Buch. Nun haben wir also eine ausführbare Datei, unter Windows ein .exe. Bevor wir nun zum Kapitel Elementare Datentypen, Konstanten und Variablen übergehen, schieben wir ein allgemeineres Kapitel über den Computer ein. |
|||||||||||||||||||||||||||||||||||||||||||||
Der PC und mein Programm |
|||||||||||||||||||||||||||||||||||||||||||||
Hier also ein Kapitel zum allgemeinen Verständnis. |
|||||||||||||||||||||||||||||||||||||||||||||
Die CPU (Central Processing Unit) oder - auf Deutsch - der Prozessor in einem PC kann nicht viel mehr als Daten im Speicher (RAM) lesen oder schreiben. Weiter kann die CPU diese Daten in interne Register holen und mit diesen einfache Berechnungen anstellen. |
|||||||||||||||||||||||||||||||||||||||||||||
Ein Programm ist ein Haufen Befehle, die in den Speicher gelesen werden
und die dann Schritt für Schritt abgearbeitet werden, wobei ein Programm
während dem es läuft noch mehr Speicher beanspruchen kann um Zwischenergebnisse
(als Variablen) zu speichern. |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Dabei ist ein Variablenname wie Zahl1 nichts anderes als eine Speicherstelle, der man einen Namen gegeben hat. Der Speicher kann dann ungefähr so aussehen: |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Ihr habt vielleicht bemerkt, dass die Adressen bei den Variablen immer um 4 erhöht werden. Das kommt daher, dass in einer Adresse immer nur 8 Bit Platz haben. Ein Bit kann dabei nur einen Wert 0 oder 1 haben. Im Zweiersystem ergibt das nur Zahlen von 0 bis 255 : |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Will man grössere Zahlen bearbeiten braucht man mehr als 8 Bit oder ein Byte. Bei meinem System meistens 4 Byte oder 32 Bit. |
|||||||||||||||||||||||||||||||||||||||||||||
Variablen bedeuten Speicherplatz Wollen wir also Zahlen in Variablen speichern, die grösser sind als 255, brauchen wir mehr bits. Damit der Compiler weiss wieviel Platz eine Variable brauchen wird, um sie mit anderen Variablen im Speicher anzuordnen, ist er auf die Entscheidung des Programmierers angewiesen, der bei der Definition angibt wieviel Speicher seine Variable brauchen soll. Will er also eine grössere Zahl in einer Variable wählt er einen Datentyp, der mehr Speicher braucht. |
|||||||||||||||||||||||||||||||||||||||||||||
Vorzeichen oder nicht ? Mit dem Datentyp wird aber auch noch etwas anderes bestimmt, nämlich ob eine Zahl ein Vorzeichen haben kann oder nicht. Dabei wird das höchstwertige Bit, also das mit dem grössten Exponenten als Vorzeichenbit verwendet. Wenn wir also einen Datentyp mit 8 Bit verwenden sieht die Wertigkeit der Bits wie folgt aus: |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Und die Werte, die sich aus den Bitmustern ergeben sehen wie folgt aus : |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Das heisst mit 8 Bit können wir die Zahlen von -128 bis 127 abbilden. Die Unterscheidung von Vorzeichenlosen Variablen und solchen mit Vorzeichen ist für den Compiler wichtig, weil der erzeugte Assemblercode sich je nachdem unterscheidet ob die CPU mit oder ohne Vorzeichen rechnen muss. Der Datentyp, der nur ein Byte verwendet wird wird char genannt, was der Kurzform von character (Buchstaben) entspricht. Das kommt daher, dass man einmal dachte, dass man alle Buchstaben und Sonderzeichen mit 8 bits darstellen kann. Den 255 möglichen Kombinationen hat man allen Buchstaben, Ziffern und Sonderzeichen zugeordnet. Der gebräuchliche Zeichensatz ist der ASCII Zeichensatz. Gemäss ASCII Zeichensatz ist folgendes Bitmuster gleich dem 'A' im Alphabet : 01000001 (Dezimahl 65). Der float und der double Datentyp werden vom Compiler und von der CPU noch einmal anders behandelt, die Bitmuster haben ein ganz andere Bedeutung und müssen anders verrechnet werden. Das sieht man auch daran, dass solche Berechnungen in vielen Systemen (z.B. im PC) von einer FPU (Floating Point Unit) erledigt werden. |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Variablen und Datentypen |
|||||||||||||||||||||||||||||||||||||||||||||
Je nach Aufgabe, die wir lösen wollen, müssen wir Daten verschieden
behandeln. So macht es für die CPU einen Unterschied ob zwei vorzeichenlose
Zahlen addiert werden sollen oder solche mit Vorzeichen. Sind die Zahlen,
mit denen wir rechnen wollen sogar Gleitkommazahlen, können Berechnungen
in der FPU (floating point unit) des Rechners gemacht werden. |
|||||||||||||||||||||||||||||||||||||||||||||
Für C++ bedeutet es, dass wir um Variablen zu erzeugen auch einen sogenannten Datentypen angeben müssen. Hier eine gültige Variablendefinition: |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
short bezeichnet den Datentypen, "eineZahl" ist der Name der Variable. Wir können also in der Variable "eineZahl" eine Zahl im Bereich zwischen -32768 und 32767 speichern. Betrachten wie ein einfaches Beispiel : |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Die Zeile nach dem Kommentar ("int meineErsteVariable"), sagt
dem Compiler, dass er Speicherplatz für eine Variable vom Datentyp
int anlegen soll. Bei meinem Compiler weiss
ich, dass das vier Byte (=32 Bit) sind. Dieser Speicherplatz bekommt in
meinem Programm stellvertretend den Namen "meineErsteVariable". |
|||||||||||||||||||||||||||||||||||||||||||||
Ein weiteres Beispiel zeigt gleich noch wie man einer Variablen gleich beim Erzeugen einen Wert geben kann. Man bezeichnet das als "initialisieren". |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Das initialisieren der Variablen ist etwas wichtiges, denn nur wenn die Variable initialisiert wurde hat sie einen definierten Wert. Ansonsten hat eine Variable einen zufälligen Wert. Wir dürfen aber beim Programmieren nichts dem Zufall überlassen! |
|||||||||||||||||||||||||||||||||||||||||||||
Versuchen wir auch noch gleich ein Programm mit mehreren Variablen zu erstellen ! |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Den Variablen werden zuerst mit der Konstanten 0 initialisiert.
Danach werden den Variablen "zahl1" und "zahl2" der
Wert 10 bzw. 20 "zugewiesen". 10 und 20 sind wieder ganzzahlige
Konstanten. |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Die Variable zahl3 ist eine Fliesskommazahl. Sie wird mit der Konstanten
3.25 initialisiert. Diese Konstante ist also eine Gleitkommakonstante. |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Von der Tastatur einlesen |
|||||||||||||||||||||||||||||||||||||||||||||
Bis jetzt haben wir Daten ausgegeben, indem wir sie an die Konsole "geschickt" haben, mittels : |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Genauso wie es ein "console out" gibt, gibt es einen "console in" : cin ! Hier gleich ein kleines Beispiel : |
|||||||||||||||||||||||||||||||||||||||||||||
|
|||||||||||||||||||||||||||||||||||||||||||||
Die fette Zeile zeigt wie man cin verwendet. Man lässt die
Daten von der Tastatur mittels ">>" in die Variable "strömen". |