C-Pointer (Zeiger, Adressen) vs. C++ Referenzen
|
|
- Ingelore Böhme
- vor 6 Jahren
- Abrufe
Transkript
1 C-Pointer (Zeiger, Adressen) vs. C++ Referenzen Der Pointer (C/C++): In C/C++ ist der Pointer ein eigener Datentyp, der auf Variablen/Objekte zeigen kann. Indem man den Pointer dereferenziert, gewinnt man das Datenobjekt zurück, auf das der Pointer zeigt. Der Dereferenzierungs-Operator in C/C++ ist der Stern * und wird vor den Pointer geschrieben: Ist p ein Pointer, der auf ein Objekt zeigt, dann ist *p dieses Objekt. Ist x ein Objekt, so ist &x ein Pointer auf dieses Objekt. Definition von Pointern: In C/C++ definiert man den Typ des dereferenzierten Objekts, z.b. int *p; double *r; // definiert p als Pointer auf einen int: (*p) ist ein int // Pointer auf ein double-objekt int n, x[20], *q; // definiert einen int n, ein Array x[20], einen Pointer q In C++ ist es eher üblich, den Pointer als "eigenen Datentyp" zu betrachten und schreibt daher oft: int* p; // p ist int-pointer Da aber C und C++ dieselbe Syntax haben, muss man aufpassen: in C: int *p, n; // p ist int-pointer, n ist int in C++: int* p, n; // p ist int-pointer, n ist int (nicht int*) Achtung: Bei der Definition eines Pointers wird der Speicherplatz für diese Pointer-Variable reserviert. Der Pointer zeigt nach der Definition noch nicht auf irgendein Datenobjekt, auch wird kein Platz für das Datenobjekt selbst reserviert. Pointer auf unterschiedliche Objektklassen sind inkompatibel. p = 1; // p wird auf die Adresse 1 gerichtet; ziemlich sinnfrei *p = 1; // das Objekt, auf das p zeigt, wird auf 1 gesetzt, hier sicher Absturz
2 q = p; r = p; p = &n; // in Ordnung, beides sind Pointer auf int // Warnung: Die Pointer (double*) und (int*) sind inkompatibel // korrekt: p zeigt ab jetzt auf n *p = 5; // ist dasselbe wie: n = 5 p = &x[4]; // p zeigt jetzt auf x[4] *p = -17; // dasselbe wie x[4] = -17 Verwendung von Pointern Abgesehen von obigen eher unsinnigen Anwendungen werden Pointer aus 2 Gründen verwendet: 1) Zur Geschwindigkeitsoptimierung in kritischen Programmteilen 2) Zur Übergabe von Objekten an Funktionen ad 2): Aus folgenden Gründen ist es sinnvoll und oft auch notwendig, statt einer Kopie des Objekts einen Pointer(oder eine Referenz) auf das Objekt zu übergeben: 1) Man kann keine Kopie des Objekts erstellen (z.b. Funktionen). Diese können nur per Pointer (oder per Referenz) übergeben werden. 2) Man will das Objekt in der Funktion ändern. Das geht nur über einen Pointer (call by address). Der Pointer wird als Kopie übergeben (C kann nur Wertübergabe!) 3) Das Kopieren des Objekts benötigt zu viel Zeit oder Speicherplatz und ist unnötig. 4) Es ist wichtig, dass das Objekt nur einmal existiert (z.b. FILE, eine Struktur für die Dateiverwaltung ). In C/C++ können Funktionen die per Kopie übergebenen (call by value) Argumente des Aufrufers nicht ändern. Das funktioniert erst dann, wenn man Pointer auf diese Objekte oder aber "getarnte Pointer = Referenzen" in C++ übergibt. void set5(int n) // total sinnlose Funktion, soll n beim Aufrufer auf 5 setzen, das geht so nicht { n = 5; irgendwo anders im Programm steht: int i = 1; set5(i);
3 Welchen Wert hat die Variable i nach diesen 2 Zeilen? Man stellt fest, dass sie immer noch den Wert 1 hat. Beim Aufruf von set5(i) wird die Variable i kopiert (diese Kopie hat den Anfangswert 1) und diese Kopie wird der Funktion set5 als Argument n übergeben. Diese ändert nun diese Kopie auf 5, aber das Original i wird NICHT verändert. Sollen Funktionen die Original-Aufruf-Parameter ändern, so muss man die Adressen der Objekte oder Referenzen auf die Objekte übergeben. Unser Programm lautet verbessert: void set5(int* p) // p zeigt auf das zu verändernde int-objekt { *p = 5; // verändere das referenzierte Objekt! irgendwo anders im Programm steht: int i = 1; set5(&i); // übergibt den Pointer &i; i hat danach den Wert 5. Die Referenz (nur C++) In C++ gibt es zusätzlich noch die Referenzen. Diese können ähnlich wie Pointer eingesetzt werden, haben aber eine ganz andere Syntax und gehorchen auch anderen Regeln. Eine Referenz ist kein eigener Datentyp sondern ein Alias-Name für das Originalobjekt. Eine Referenz muss immer auf ein existierendes Objekt zeigen und bleibt dauerhaft mit diesem Objekt verbunden! Eine Referenz muss nicht (kann nicht!) dereferenziert werden. int i; int& i2 = i; int* p; int& j; // korrekt: Referenz i2 ist ein Alias für i // korrekt: Pointer p zeigt auf nichts // Fehler: Referenz j zeigt auf nichts i2 = 5; // ändert das Original i (hier steht kein *) p = &i; // richtet p auf i *p = 7; // ändert i (bei Pointern muss hier der * stehen) Mit Referenzen lässt sich das vorige Programm so schreiben: void set5(int& r) // r referenziert das übergebene int-objekt { r = 5; // verändere das referenzierte Objekt! irgendwo anders im Programm steht:
4 int i = 1; set5(i); // i hat danach den Wert 5. Hier darf beim Aufruf kein Adress-Operator stehen Obwohl Referenzen und Pointer eng verwandt sind, gibt es 2 Hauptunterschiede: 1) Eine Referenz zeigt immer auf das Element, auf das sie konstruiert wurde. Ein Pointer kann auch umdefiniert werden und kann dann andere Ziele anvisieren. 2) Eine Referenz muss beim Erstellen auf ein existierendes Objekt verweisen. Ein Pointer kann auch ins Nirvana zeigen (z.b. der Nullpointer, der die Adresse 0 anvisiert). Nullpointer als Ergebnisse werden in C oft auch zur Signalisierung eines Fehlers eingesetzt: if (fopen(filename, "r") == 0) // das Öffnen der Datei hat nicht geklappt. Referenzen lassen sich nicht zu diesem Zweck einsetzen, da das Ziel der Referenz, wie gesagt, immer gültig sein muss: Es gibt keine Null-Referenz! Arrays und Pointer Arrays(Felder) und Pointer sind in C/C++ eng verwandt, genauer gesagt ist ein Array ein nicht-veränderbarer Pointer auf das nullte Array-Element. Genauso kann man Pointer mit Index-Klammern verwenden, als wären sie Arrays. ACHTUNG: Bei der Definition eines Arrays wird Speicherplatz für alle Elemente reserviert. Bei der Definition eines Pointers wird nur der Platz für die Pointervariable selbst reserviert. int some_integers[30], *ip; // int Array der Länge 30 und ein Pointer ip ip = some_integers; ip = &some_integers[0]; // korrekt, ip zeigt auf some_integers[0] // korrekt, ist dasselbe some_integers[5] = ip[10]; // korrekt, ip als array interpretiert some_integers = ip; *ip = *some_integers; // FEHLER: some_integers ist konstanter Pointer // korrekt, interpretiere some_integers als // pointer. *some_integers ist dasselbe wie some_integers[0] ip = some_integers + 2; // korrekt: rechte Seite: Pointer + int gibt Pointer auf // das Arrayelement mit dem Index 2
5 ip = &some_integers[2]; // ist genau dasselbe wie voriges Statement *ip == some_integers[2]; // korrekt und TRUE, da es DIESELBE SPEICHERZELLE ist Innerhalb der Funktion, in der ein Array definiert wurde, ist bekannt, dass es sich um ein Array handelt. Insbesondere ist auch die Dimension bekannt, da dafür eine Konstante verwendet werden muss. Bei der Übergabe eines Arrays an eine Funktion ist in der aufgerufenen Funktion nur mehr der Pointer vorhanden (kein Array und es ist auch die Dimension unbekannt). Arrays zerfallen durch die Übergabe zu reinen Pointern: void print(double v[3]) Obiger Funktionskopf ist legal, aber absolut irreführend. Es handelt sich bei v um ein Argument, das an die Funktion print übergeben wird. Dies ist demnach ein reiner Pointer und die Angabe der Dimension [3] ist unnütz und gefährlich. Es wird suggeriert, dass C/C++ dem eine Bedeutung schenken. Das ist NICHT DER FALL. Diese Funktion wird von C/C++ umgewandelt zu void print(double* v) und sollte auch genauso definiert werden! Deshalb sollte die Dimension zusätzlich übergeben werden: void print(double* v, unsigned dim) // dim: Dimension von v Aber Achtung: double v[3]; Das ist eine Definition eines Objekts und die Dimension ist hier tatsächlich Teil des Objekttyps. Übergibt man ein Array an eine Funktion, so erhält diese nur einen Pointer auf das Startelement. Mit diesem Pointer kann das Originalarray immer verändert werden. Zur Indexüberwachung sollte die Dimension des Arrays als zusätzliches Argument mit übergeben werden. Die C++ Container-Template-Klassen sind keine Arrays und damit auch keine Pointer! Will man sie an Funktionen übergeben und von diesen verändern lassen, muss man sie per Pointer (bitte nicht!!!!) oder viel besser per Referenz übergeben! Da sie ihre Länge kennen, ist kein weiteres Argument nötig.
6 void f1(std::vector<double> x) // erwartet eine vector-kopie, kann Original nicht ändern void f2(std::vector<double>* x) // erwartet einen Pointer auf den vector, kann diesen ändern // z.b. (*x)[5] = 3; // aber bitte nicht das falsche: *x[5] = 3; ) void f1(std::vector<double>& x) // erwartet eine vector-referenz, kann Original ändern (z.b. x[5] = 3; ) Pointer-Arithmetik: Für Pointer sind folgende Rechenoperationen erlaubt: Pointer + Integer, Pointer - Integer, Pointer++, ++Pointer, Pointer--, --Pointer Die Adressen ändern sich immer um Vielfache der Basistyps, d.h. es gilt für jeden Pointer p: p + 1 == &(p[1]); // zeigt auf das Array-Element mit dem Index 1 p + n == &(p[n]); p++; // p zeigt jetzt auf das nächste Objekt in dem Feld Außerdem gibt es die int-differenz: Pointer - Pointer (nur für Pointer auf denselben Typ!) ist der Indexunterschied der Elemente: int feld[10], p = &feld[3], q = &feld[7]; q-p; // hat den Wert 7-3, also 4 p-q; // hat den Wert 3-7, also -4
7 Pointer auf Funktionen Für mathematische Algorithmen ist oft die Übergabe von Funktionen erforderlich z.b. bei der numerischen Differentiation oder Integration: Man möchte gerne die zu differenzierende oder zu integrierende Funktion als Parameter übergeben. Dies lässt sich in C "sehr leicht" durch einen Pointer auf die Funktion erledigen: Ist z.b. die reelle Quadrier-Funktion f(x) in C realisiert als double f(double x) { return x*x; so ist &f ein Pointer auf diese Funktion und kann z.b. an eine Funktion numdiff (die f numerisch an einer Stelle a differenziert) weitergegeben werden. Die einzige Schwierigkeit (aber die ist beachtlich), ist die korrekte Deklaration des Funktionspointer-Parameters &f in numdiff: Diese erwartet also einen Pointer p auf eine Funktion, d.h. (*p) ist diese Funktion. Eine Funktion in C ist etwas, was aufgerufen werden kann, was mit dem Aufrufoperator () geschieht. diese Funktion nimmt ein double-argument entgegen und hat ein double Ergebnis. Damit landet man bei double (*p)(double)für p. double numdiff(double (*p)(double), double a) // p ist Pointer auf Funktion, a die Stelle, an der differenziert werden soll { double h=1e-6; // eine gute Wahl f. h return ( (*p)(a+h) - (*p)(a-h) )/(2*h); // so sieht der Aufruf von *p aus. Beachte die Klammern! In C++ und in C seit C99 werden Funktionen automatisch in Pointer umgewandelt, der Adressoperator darf hier weggelassen werden. Ebenso muss nicht dereferenziert werden. Somit kann man obiges einfacher schreiben als: double numdiff(double f(double), double a) // f ist Pointer auf Funktion, a die Stelle, an der differenziert werden soll { double h=1e-6; // eine gute Wahl f. h return ( f(a+h) - f(a-h) )/(2*h);
8 Pointer auf Pointer und Pointer-Arrays C erlaubt es, Pointer auf Felder, Pointer auf Pointer, Felder von Pointern usw. zu definieren. Ich empfehle hier Klammern zu setzen, wenn man ganz sicher sein will! Manche dieser Konstruktionen sind sinnvoll und werden im Weiteren benötigt. int** p; *p; **p; // ein Pointer auf einen Pointer vom Typ int, wird gebraucht // Pointer auf einen Integer // der Integer char (*p)[20]; // p zeigt auf ein char-feld der Länge 20 char* (p[20]); // Feld von 20 Pointern, die alle auf einen char zeigen // einfach ausgedrückt: Feld von 20 Strings char* p[20]; int* p() // genau dasselbe, wird gebraucht // p ist eine Funktion die einen int-pointer retourniert // dürfte eher selten so gewollt sein int (*p)(); // p ist ein Pointer auf eine Funktion, die einen // int-rückgabewert hat, wird gebraucht int p(); // dasselbe, aber einfacher (in C++ und ab C99) Pointerartige Objekte in C++ C++ kennt zusätzliche Objekttypen, die ähnlich wie Pointer verwendet werden können. Dazu zählen z.b. die Iteratoren der Container-Templates und die Smartpointer von C++ (std::shared_ptr und std::unique_ptr). Diese können immer dereferenziert werden (wie echte Pointer) und gestatten auch weitere Pointeroperationen (je nach Typ): Manche lassen sich inkrementieren und dekrementieren, definieren einen Indexoperator usw. Die klassische for-schleife durch [first, last): for (auto it = first; it!= last; ++it) Tue etwas mit *it:
2. Programmierung in C
2. Programmierung in C Inhalt: Überblick über Programmiersprachen, Allgemeines zur Sprache C C: Basisdatentypen, Variablen, Konstanten, Operatoren und Ausdrücke Anweisungen und Kontrollstrukturen (Steuerfluss)
MehrInhalt. 4.5 Arbeit mit Zeigern (engl. Pointer)
Inhalt Inhalt: 4. Programmiersprache C 4.1 Programmaufbau in C 4.2 Basisdatentypen und einfache Anweisungen 4.3 Steuerfluss-Konstrukte 4.4 Arbeit mit indizierten Größen (Felder) 4.5 Arbeit mit Zeigern
MehrDeklarationen in C. Prof. Dr. Margarita Esponda
Deklarationen in C 1 Deklarationen Deklarationen spielen eine zentrale Rolle in der C-Programmiersprache. Deklarationen Variablen Funktionen Die Deklarationen von Variablen und Funktionen haben viele Gemeinsamkeiten.
MehrEinstieg in die Informatik mit Java
1 / 34 Einstieg in die Informatik mit Java Klassen mit Instanzmethoden Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 34 1 Definition von Klassen 2 Methoden 3 Methoden
MehrProgrammierung mit C Zeiger
Programmierung mit C Zeiger Zeiger (Pointer)... ist eine Variable, die die Adresse eines Speicherbereichs enthält. Der Speicherbereich kann... kann den Wert einer Variablen enthalten oder... dynamisch
Mehr7 Funktionen. 7.1 Definition. Prototyp-Syntax: {Speicherklasse} {Typ} Name ({formale Parameter});
S. d. I.: Programieren in C Folie 7-1 7 Funktionen 7.1 Definition Prototyp-Syntax: Speicherklasse Typ Name (formale Parameter); der Funktions-Prototyp deklariert eine Funktion, d.h. er enthält noch nicht
Mehr1. Referenzdatentypen: Felder und Strings. Referenz- vs. einfache Datentypen. Rückblick: Einfache Datentypen (1) 4711 r
1. Felder und Strings Eigenschaften von Referenzdatentypen 1. Referenzdatentypen: Felder und Strings Referenzdatentypen sind Konstrukte, mit deren Hilfe wir aus einfachen Datentypen neue eigene Typen erzeugen
MehrProgrammiersprache 1 (C++) Prof. Dr. Stefan Enderle NTA Isny
Programmiersprache 1 (C++) Prof. Dr. Stefan Enderle NTA Isny 7. Funktionen Einleitung Nach dem Prinzip Divide and Conquer bietet es sich an, größere Aufgaben in kleinere Teile zu unterteilen. Anweisungsblöcke,
MehrJavaScript. Dies ist normales HTML. Hallo Welt! Dies ist JavaScript. Wieder normales HTML.
JavaScript JavaScript wird direkt in HTML-Dokumente eingebunden. Gib folgende Zeilen mit einem Texteditor (Notepad) ein: (Falls der Editor nicht gefunden wird, öffne im Browser eine Datei mit der Endung
MehrArrays (Felder/Vektoren)
Arrays (Felder/Vektoren) Zusammenfassung mehrerer Variablen des gleichen Typs unter einem Namen im Speicher direkt hintereinander abgelegt Definition: Typname Arrayname [Größe]; Beispiel: int ar [5]; Zugriff
MehrWertebereich und Genauigkeit der Zahlendarstellung
Wertebereich und Genauigkeit der Zahlendarstellung Sowohl F als auch C kennen bei ganzen und Floating Point-Zahlen Datentypen verschiedener Genauigkeit. Bei ganzen Zahlen, die stets exakt dargestellt werden
MehrProgrammieren in C. Zeiger und Zeichenketten. Prof. Dr. Nikolaus Wulff
Programmieren in C Zeiger und Zeichenketten Prof. Dr. Nikolaus Wulff Zeiger Variablen benötigen zur Laufzeit einen bestimmten Speicherplatz. Die Größe des Bedarfs richtet sich nach dem Typ der Variablen,
MehrC++ Teil 5. Sven Groß. 13. Mai Sven Groß (IGPM, RWTH Aachen) C++ Teil Mai / 18
C++ Teil 5 Sven Groß 13. Mai 2016 Sven Groß (IGPM, RWTH Aachen) C++ Teil 5 13. Mai 2016 1 / 18 Themen der letzten Vorlesung Funktionen Funktionsüberladung, Signatur Rekursion const-deklaration Referenzen
MehrWas Mathematiker schon vor Jahrhunderten erfunden haben, gibt es jetzt endlich in ihrer Programmiersprache:
Kapitel 8 Operatoren Was Mathematiker schon vor Jahrhunderten erfunden haben, gibt es jetzt endlich in ihrer Programmiersprache: Operatoren definieren Es ist in C++ möglich, Operatoren wie +, oder für
MehrZeiger, Arrays und Strings in C und C++
Zeiger, Arrays und Strings in C und C++ 1 Zeiger in Java und C/C++ Zeigervariable (kurz: Zeiger, engl.: pointer): eine Variable, die als Wert eine Speicheradresse enthält Java: Zeiger werden implizit für
MehrZeiger: Der Adressoperator &
Zeiger: Der Adressoperator & Variablen werden im Computer im Speicher abgelegt. Nach der Deklaration int a,b,c; double x,y,z; Sieht die Speicherbelegung etwa wie folgt aus: a b c x y z Jede Variable hat
MehrÜbung zur Vorlesung Programmieren in C
Übung zur Vorlesung Programmieren in C 6 Pointers Marvin Gülker Ruhruniversität Bochum Wintersemester 2015/2016 Marvin Gülker (Ruhruniversität Bochum) 6 Pointers Wintersemester 2015/2016 1 / 29 Gliederung
MehrProzeduren und Funktionen
OSZ Handel I - Gymnasiale Oberstufe (Abt. V) In Anlehnung an: Duden Informatik (3.Auflage, Dudenverlag, 2001, S. 477). Prozeduren und Funktionen Fach: Informatik Parameter sind Platzhalter in einer Prozedur
MehrKapitel 4: Zeiger. Inhalt. Zeiger Zeigerarithmetik
Wintersemester 2005/06 Einführung in die Informatik für Naturwissenschaftler und Ingenieure (alias Einführung in die Programmierung) (Vorlesung) Prof. Dr. Günter Rudolph Fachbereich Informatik Lehrstuhl
MehrGrundlagen der Informatik 11. Zeiger
11. Zeiger Motivation Zeiger und Adressen Zeiger und Funktionen Zeiger und Arrays Dynamische Objekte Grundlagen der Informatik (Alex Rempel) 1 Motivation Dynamische Speicherverwaltung Oft müssen große
MehrProgrammieren in C. Funktionen mit Zeigern und Adressen. Prof. Dr. Nikolaus Wulff
Programmieren in C Funktionen mit Zeigern und Adressen Prof. Dr. Nikolaus Wulff ByValue versus byreferenz C übergibt immer Kopien der Variablen an Funktionen. Es ist nur dann möglich die Werte von Variablen
MehrVorkurs C++ Programmierung
Vorkurs C++ Programmierung Funktionen Rückblick Operatoren logische Verknüpfungen Zusammengesetzte Operatoren ( Zuweisungsoperatoren ) Kontrollstrukturen Bedingte Anweisungen (if-abfrage, switch-konstrukt)
MehrAlgorithmen und Programmierung II
Algorithmen und Programmierung II Vererbung Prof. Dr. Margarita Esponda SS 2012 1 Imperative Grundbestandteile Parameterübergabe String-Klasse Array-Klasse Konzepte objektorientierter Programmierung Vererbung
MehrModellierung und Programmierung 1
Modellierung und Programmierung 1 Prof. Dr. Sonja Prohaska Computational EvoDevo Group Institut für Informatik Universität Leipzig 19. November 2015 Gültigkeitsbereich (Scope) von Variablen { int m; {
MehrProgrammiersprache 1 (C++) Prof. Dr. Stefan Enderle NTA Isny
Programmiersprache 1 (C++) Prof. Dr. Stefan Enderle NTA Isny 9. Zeiger Arbeitsspeicher / Adressen Der Arbeitsspeicher des Computers (RAM) besteht aus einem Feld von Speicherzellen, beginnend bei Adresse
MehrC++ Notnagel. Ziel, Inhalt. Programmieren in C++
C++ Notnagel Ziel, Inhalt Ich versuche in diesem Dokument noch einmal die Dinge zu erwähnen, die mir als absolut notwendig für den C++ Unterricht und die Prüfungen erscheinen. C++ Notnagel 1 Ziel, Inhalt
MehrVorkurs C++ Programmierung
Vorkurs C++ Programmierung Klassen Letzte Stunde Speicherverwaltung automatische Speicherverwaltung auf dem Stack dynamische Speicherverwaltung auf dem Heap new/new[] und delete/delete[] Speicherklassen:
MehrBereits behandelt: Einfache Datentypen / Variablen. Schleifen und Verzweigungen. Funktionen. Heute: Felder, Zeiger, Referenzen. Freispeicherverwaltung
Kompaktkurs C++ Themen C 1 Bereits behandelt: Einfache Datentypen / Variablen Schleifen und Verzweigungen Funktionen Heute: Felder, Zeiger, Referenzen Freispeicherverwaltung Zeichenketten Kommandozeilenargumente
Mehr1. Übung zu "Numerik partieller Differentialgleichungen"
1. Übung zu "Numerik partieller Differentialgleichungen" Simon Gawlok, Eva Treiber Engineering Mathematics and Computing Lab 22. Oktober 2014 1 / 15 1 Organisatorisches 2 3 4 2 / 15 Organisatorisches Ort:
MehrEinführung in den Einsatz von Objekt-Orientierung mit C++ I
Einführung in den Einsatz von Objekt-Orientierung mit C++ I ADV-Seminar Leiter: Mag. Michael Hahsler Syntax von C++ Grundlagen Übersetzung Formale Syntaxüberprüfung Ausgabe/Eingabe Funktion main() Variablen
MehrC++ Teil 6. Sven Groß. 27. Mai Sven Groß (IGPM, RWTH Aachen) C++ Teil Mai / 14
C++ Teil 6 Sven Groß 27. Mai 2016 Sven Groß (IGPM, RWTH Aachen) C++ Teil 6 27. Mai 2016 1 / 14 Themen der letzten Vorlesung Musterlösung A2 Wdh.: Zeiger und Felder Kopieren von Feldern Dynamische Speicherverwaltung
MehrEinstieg in die Informatik mit Java
1 / 26 Einstieg in die Informatik mit Java Felder Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 26 1 Was sind Felder? 2 Vereinbarung von Feldern 3 Erzeugen von Feldern
MehrJava programmieren mit JavaKara. Eine Zusammenfassung in Beispielen
Java programmieren mit JavaKara Eine Zusammenfassung in Beispielen Kleeblätter in einer Zeile zählen @Override public void mymainprogram() { int anzahlkleeblaetter = 0; for (int x = 0; x < world.getsizex();
MehrTyp : void* aktuelle Parameter Pointer von beliebigem Typ
2. Funktionen - Prototypvereinbarung typangabe funktionsname(parameterliste); - Funktionsdefinition typ funktionsname(parameterliste){ Anweisung - Funktionstyp -> Typ der Funktionswertes zulaessige Typangaben
MehrRO-Tutorien 3 / 6 / 12
RO-Tutorien 3 / 6 / 12 Tutorien zur Vorlesung Rechnerorganisation Christian A. Mandery WOCHE 2 AM 06./07.05.2013 KIT Universität des Landes Baden-Württemberg und nationales Forschungszentrum in der Helmholtz-Gemeinschaft
MehrC- Kurs 08 Zeiger. Dipl.- Inf. Jörn Hoffmann leipzig.de. Universität Leipzig Ins?tut für Informa?k Technische Informa?
C- Kurs 08 Dipl.- Inf. Jörn Hoffmann jhoffmann@informa?k.uni- leipzig.de Universität Leipzig Ins?tut für Informa?k Technische Informa?k Überblick Datentyp zur Verwaltung von Adressen (auf Speicherplätze)
MehrProgrammieren in C. Zeiger auf Funktionen. Prof. Dr. Nikolaus Wulff
Programmieren in C Zeiger auf Funktionen Prof. Dr. Nikolaus Wulff Zeiger auf Funktionen Zeiger verweisen auf beliebige Speicherstellen. Im Allgemeinen werden Zeiger ausgerichtet auf Variablen, wie z. B.
MehrZeiger in C und C++ Zeiger in Java und C/C++
1 Zeiger in Java und C/C++ Zeigervariable (kurz: Zeiger, engl.: pointer): eine Variable, die als Wert eine Speicheradresse enthält Java: Zeiger werden implizit für Referenztypen (Klassen und Arrays) verwendet,
MehrUnterprogramme. Funktionen. Bedeutung von Funktionen in C++ Definition einer Funktion. Definition einer Prozedur
Unterprogramme Unterprogramme sind abgekapselte Programmfragmente, welche es erlauben, bestimmte Aufgaben in wiederverwendbarer Art umzusetzen. Man unterscheidet zwischen Unterprogrammen mit Rückgabewert
MehrFunktionen Häufig müssen bestimmte Operationen in einem Programm mehrmals ausgeführt werden. Schlechte Lösung: Gute Lösung:
Funktionen Häufig müssen bestimmte Operationen in einem Programm mehrmals ausgeführt werden. Schlechte Lösung: Der Sourcecode wird an den entsprechenden Stellen im Programm wiederholt Programm wird lang
MehrEinstieg in die Informatik mit Java
Vorlesung vom 18.4.07, Variablen Übersicht 1 Variablendeklaration 2 Initialisierung von Variablen 3 Symbolische Konstanten Variablendeklaration Die Deklaration der Variablen erfolgt durch eine Typangabe
MehrEinführung in die Programmierung Arrays, Zeiger, Strings. Arvid Terzibaschian
Einführung in die Programmierung Arvid Terzibaschian 1 Arrays 2 Arrays: Motivation Gegeben: monatliche Durchschnittstemperaturen der letzten 5 Jahre Gesucht: Mittelwerte für Jahre, Monate, Jahreszeiten,
MehrPass by Value Pass by Reference Defaults, Overloading, variable Parameteranzahl
Funktionen Zusammenfassung von Befehlssequenzen als aufrufbare/wiederverwendbare Funktionen in einem Programmblock mit festgelegter Schnittstelle (Signatur) Derartige prozedurale Programmierung erlaubt
MehrObjektorientierte Programmierung mit C++ Vector und List
Vector und List Ziel, Inhalt Wir lernen die Klassen vector und list aus der Standard-C++ Library kennen und anwenden. In einer Übung wenden wir diese Klassen an um einen Medienshop (CD s und Bücher) zu
MehrBereits behandelt: Einfache Datentypen / Variablen. Schleifen und Verzweigungen. Funktionen. Heute: Felder, Zeiger, Referenzen. Freispeicherverwaltung
Kompaktkurs C++ Themen C 1 Bereits behandelt: Einfache Datentypen / Variablen Schleifen und Verzweigungen Funktionen Heute: Felder, Zeiger, Referenzen Freispeicherverwaltung Zeichenketten Kommandozeilenargumente
MehrÜbersicht. Informatik 1 Teil 9: komplexe Datentypen (Strukturen, Enumerationen, Unions)
Übersicht 9.1 Strukturen (Verwendung) 9.2 Strukturen (Typdeklaration) 9.3 Strukturen (Variablendeklaration) 9.4 Felder aus Strukturen 9.5 Zugriff auf Strukturkomponenten 9.6 Zugriff auf Strukturkomponenten
MehrDie for -Schleife HEUTE. Schleifen. Arrays. Schleifen in JAVA. while, do reichen aus, um alle iterativen Algorithmen zu beschreiben
18.11.5 1 HEUTE 18.11.5 3 Schleifen Arrays while, do reichen aus, um alle iterativen Algorithmen zu beschreiben Nachteil: Steuermechanismus ist verteilt Übersicht nicht immer leicht dazu gibt es for (
MehrVerschlüsseln eines Bildes. Visuelle Kryptographie. Verschlüsseln eines Bildes. Verschlüsseln eines Bildes
Verschlüsseln eines Bildes Visuelle Kryptographie Anwendung von Zufallszahlen Wir wollen ein Bild an Alice und Bob schicken, so dass Alice allein keine Information über das Bild bekommt Bob allein keine
MehrJava I Vorlesung 6 Referenz-Datentypen
Java I Vorlesung 6 Referenz-Datentypen 7.6.2004 Referenzen this, super und null Typkonvertierung von Referenztypen Finale Methoden und Klassen Datentypen in Java In Java gibt es zwei Arten von Datentypen:
MehrTag 4 Repetitorium Informatik (Java)
Tag 4 Repetitorium Informatik (Java) Dozent: Patrick Kreutzer Lehrstuhl für Informatik 2 (Programmiersysteme) Friedrich-Alexander-Universität Erlangen-Nürnberg Wintersemester 2016/2017 Willkommen zum Informatik-Repetitorium!
MehrUnterprogramme, Pointer und die Übergabe von Arrays
Unterprogramme, Pointer und die Übergabe von Arrays Unterprogramme Wie schon im Abschnitt über Funktionen erwähnt, versteht man unter einem Unterprogramm im engeren Sinn eine Prozedur, welche die Werte
MehrProgrammieren in C/C++ und MATLAB
Programmieren in C/C++ und MATLAB Sven Willert Sabine Schmidt Christian-Albrechts-Universität zu Kiel CAU 5-1 Übung Schreiben Sie ein Programm, das die Zahl π durch π = 4 4 4 4 4 4 + + +... 3 5 7 9 11
MehrBeispiel. Problem: mehrteilige Nachnamen (von Goethe, Mac Donald, Di Caprio)
Beispiel Beispiel: Namensliste konvertieren (Karl Egon Meier Meier, Karl Egon). s/(.*) (.*)/$2, $1/; Problem: mehrteilige Nachnamen (von Goethe, Mac Donald, Di Caprio) s/(.*) (.*)/$2, $1/; s/(.*) ([a-z]+
MehrGrundlagen der Informatik. Prof. Dr. Stefan Enderle NTA Isny
Grundlagen der Informatik Prof. Dr. Stefan Enderle NTA Isny 2 Datenstrukturen 2.1 Einführung Syntax: Definition einer formalen Grammatik, um Regeln einer formalen Sprache (Programmiersprache) festzulegen.
MehrProgrammieren in C++ Überladen von Methoden und Operatoren
Programmieren in C++ Überladen von Methoden und Operatoren Inhalt Überladen von Methoden Überladen von Operatoren Implizite und explizite Konvertierungsoperatoren 7-2 Überladen von Methoden Signatur einer
MehrC/C++ Programmierung
1 C/C++ Programmierung Verbunde, Reihungen, Zeiger Sebastian Hack Christoph Mallon (hack mallon)@cs.uni-sb.de Fachbereich Informatik Universität des Saarlandes Wintersemester 2009/2010 2 Typen 6.2.5 Primitive
Mehrzu große Programme (Bildschirmseite!) zerlegen in (weitgehend) unabhängige Einheiten: Unterprogramme
Bisher Datentypen: einfach Zahlen, Wahrheitswerte, Zeichenketten zusammengesetzt Arrays (Felder) zur Verwaltung mehrerer zusammengehörender Daten desselben Datentypes eindimensional, mehrdimensional, Array-Grenzen
MehrKlausur Grundlagen der Programmierung
Klausur Grundlagen der Programmierung Aufgabenstellung: Martin Schultheiß Erreichte Punktzahl: von 60 Note: Allgemeine Hinweise: Schreiben Sie bitte Ihren Namen auf jedes der Blätter Zugelassene Hilfsmittel
MehrModul 122 VBA Scribt.docx
Modul 122 VBA-Scribt 1/5 1 Entwicklungsumgebung - ALT + F11 VBA-Entwicklungsumgebung öffnen 2 Prozeduren (Sub-Prozeduren) Eine Prozedur besteht aus folgenden Bestandteilen: [Private Public] Sub subname([byval
MehrKlausur Fachprüfung Wirtschaftsinformatik. Name:
Klausur Fachprüfung Wirtschaftsinformatik Dauer: 2 Stunden Datum: 02.10.2003 Name: Punkte True-or-False: von 15 Punkte Multiple Choice: von 15 Punkte Quickies: von 30 Punkte Shorties: von 20 Punkte Longies:
MehrModellierung und Programmierung
Modellierung und Programmierung Dr. Martin Riplinger 19.12.2012 IAM Institut für Angewandte Mathematik Funktionszeiger: Vorüberlegungen Funktionsaufrufe sind bis jetzt im Code mit Name explizit angegeben
MehrVariablen. Deklaration: «Datentyp» «Variablenname» Datentyp bestimmt Größe in Bytes: sizeof Beispiel: long int v; Größe: 4 Bytes
Variablen Deklaration: «Datentyp» «Variablenname» Datentyp bestimmt Größe in Bytes: sizeof Beispiel: long int v; Größe: 4 Bytes v ist Stück im Speicher, der 4 Bytes lang ist Speicherzugriff? Über Adressen!
MehrEinstieg in die Informatik mit Java
1 / 26 Einstieg in die Informatik mit Java Felder, mehrdimensional Gerd Bohlender Institut für Angewandte und Numerische Mathematik Gliederung 2 / 26 1 Überblick: mehrdimensionale Felder 2 Vereinbarung
MehrInteger Integer Integer (Voreinstellung) Integer Gleitkomma Gleitkomma leer/unbestimmt Integer ohne Vorzeichen Integer (explizit) mit Vorzeichen
1 C-Schlüsselwörter Schlüsselwörter sind in allen Programmiersprachen reservierte Wörter. In C sind auch alle Namen _[A-Z]... und... reserviert, auch _... bereichsweise. Weiterhin durch die Standard-
Mehr4 Kontrollfluss-Diagramme
4 Kontrollfluss-Diagramme In welcher Weise die Operationen eines Programms nacheinander ausgeführt werden, läßt sich anschaulich mithilfe von Kontrollfluss-Diagrammen darstellen. Ingredienzien: Start Stop
MehrKapitel 8. Programmierkurs. Methoden. 8.1 Methoden
Kapitel 8 Programmierkurs Birgit Engels Anna Schulze Zentrum für Angewandte Informatik Köln Objektorientierte Programmierung Methoden Überladen von Methoden Der this-zeiger Konstruktoren Vererbung WS 07/08
MehrAlgorithmen und Datenstrukturen
Algorithmen und Datenstrukturen 3.3 Mehrdimensionale Arrays W. Tasin, M.Sc. Fakultät 04 tasin@hm.edu Allgemeines (1) Ein Feld (Array) kann seinerseits als Komponente wieder ein Array besitzen. Es wird
MehrPointer überall Pointer von Jörg Jacob, Mai 2004 (Version 0.2)
Pointer überall Pointer von Jörg Jacob, Mai 004 (Version 0.) 1 Inhaltsverzeichnis 0. Die Zutaten...3 1. Allgemeines...3. Die ersten Pointer...3 3. Zugriff auf Pointer...4 4. Verwendung von Pointern...5
MehrErste Schritte der Programmierung in C
Erste Schritte der Programmierung in C C versus C++ Anatomie von C-Programmen für AVR- Mikrocontroller Unterschiede zwischen C++ und C 1 Grundlegende Unterschiede File-Extensions (Header und Quellcode)
MehrProf. W. Henrich Seite 1
Klasse - ist ein benutzerdefinierter Datentyp (Referenztyp) - hat Datenelemente - hat Methoden - Konstruktor ist spezielle Methode zum Erstellen eines Objektes vom Typ der Klasse (Instanz) - jede Klasse
MehrU3 3. Übung U3 3. Übung. Systemnahe Programmierung in C Übungen Moritz Strübe Universität Erlangen-Nürnberg Informatik 4, 2009 U3.fm
U3 3. Übung U3 3. Übung Besprechung Aufgabe 1 Pointer Register und Ports U3.1 U3-1 Zeiger U3-1 Zeiger 1 Einordnung Konstante: a 0110 0001 Variable: a Zeiger-Variable (Pointer): a char *p = &a; p U3.2 2
MehrC++ - Einführung in die Programmiersprache Funktionen. Leibniz Universität IT Services Anja Aue
C++ - Einführung in die Programmiersprache Funktionen Leibniz Universität IT Services Anja Aue Subroutine (Unterprogramm) Lösung von Teilen einer Gesamtaufgabe. Kapselung von Anweisungen, die zu einer
MehrProgrammiersprachen Einführung in C. Unser erstes C-Programm. Unser erstes C-Programm. Unser erstes C-Programm. Unser erstes C-Programm
Programmiersprachen Einführung in C Teil 2: Prof. Dr. int main (int argc, char *argv[]) int sum = 0; for (i = 0; i
MehrAssoziative Container in C++ Christian Poulter
Assoziative Container in C++ Christian Poulter Seminar: Die Sprache C++ Mat-Nr.: 53 03 129 EMail: inf@poulter.de Christian Poulter Assoziative Container in C++ Seite 1/10 Inhalt 1. Einleitung: Container...
MehrIn der Computersprache C ist die Standardmethode zur Behandlung von Matrizen durch
Kapitel Matrizen in C++ In der Computersprache C ist die Standardmethode zur Behandlung von Matrizen durch 1 const int n=10; 3 double a[n][n]; gegeben. Allerdings gibt es bei dieser Methode eine Reihe
MehrFHZ. K20 Arrays. Lernziele. Hochschule Technik+Architektur Luzern Abteilung Informatik, Fach Programmieren. Inhalt
Inhalt 1. Einführung 2. Array-Komponenten von elementaren Datentypen 3. Array-Komponenten sind Objekte 4. Array als Parameter 5. Kopieren von Arrays 6. Beispiel 7. Vector versus Array Folie 1 Lernziele
MehrMit ParamArrays unter VBA kann man Prozeduren und Funktionen mit einer flexiblen Anzahl von Parametern bestücken Kontext
Mit ParamArrays unter VBA kann man Prozeduren und Funktionen mit einer flexiblen Anzahl von Parametern bestücken Kontext Dieses Beispiel baut auf dem Artikel Anzahl Zeilen und Spalten eines Range-Objektes
MehrGrundlagen der Programmierung in C Funktionen
Der erste Mechanismus für Code-Reuse! Grundlagen der Programmierung in C Funktionen Wintersemester 2005/2006 G. Zachmann Clausthal University, Germany zach@in.tu-clausthal.de Ältester Mechanismus für Code-Reuse:
Mehr6. Zeiger Allgemeines Definition eines Zeigers
6. Zeiger www.c-programme.de Stefan Thiemert Kapitel 6 - Seite 1 von 6 6. 1. Allgemeines Zeiger spielen in der Programmierung eine wichtige Rolle. Sie sind wichtig, bei der Arbeit mit Arrays und Funktionen.
MehrModerne C-Programmierung
Xpert.press Moderne C-Programmierung Kompendium und Referenz Bearbeitet von Helmut Schellong 1. Auflage 2005. Buch. xii, 280 S. ISBN 978 3 540 23785 3 Format (B x L): 15,5 x 23,5 cm Weitere Fachgebiete
MehrKlassen mit Instanzmethoden
Klassen mit Instanzmethoden Gerd Bohlender Institut für Angewandte und Numerische Mathematik Vorlesung: Einstieg in die Informatik mit Java 3.12.07 G. Bohlender (IANM UNI Karlsruhe) OOP und Klassen 3.12.07
MehrProgrammiertechnik Klassenmethoden
Programmiertechnik Klassenmethoden Prof. Dr. Oliver Haase Oliver Haase Hochschule Konstanz 1 Motivation Programm zur Berechung von public class Eval1 { public static void main(string[] args) { java.util.scanner
MehrÜbungspaket 14 Eindimensionale Arrays
Übungspaket 14 Eindimensionale Arrays Übungsziele: Skript: Deklaration und Verwendung eindimensionaler Arrays Kapitel: 33 Semester: Wintersemester 2016/17 Betreuer: Kevin, Matthias, Thomas und Ralf Synopsis:
MehrZusammenfassung des Handzettels für Programmieren in C
Zusammenfassung des Handzettels für Programmieren in C In der handschriftlichen Kopie werden mehr Abkürzungen verwendet. Alles Grün markierte dient zum lernen und wird nicht auf den Handzettel übertragen.
MehrProgrammieren in C++ Arrays, Strings und Zeigerarithmetik
Programmieren in C++ Arrays, Strings und Zeigerarithmetik Inhalt Eindimensionale C-Arrays C-Strings und Strings (Mehrdimensionale C-Arrays) Arrays und Vektoren (C++) Unique Pointers (C++11) Zeigerarithmetik
MehrEinführung in die Programmiersprache C
Einführung in die Programmiersprache C Marcel Arndt arndt@ins.uni-bonn.de Institut für Numerische Simulation Universität Bonn Der Anfang Ein einfaches Programm, das Hello World! ausgibt: #include
MehrKapitel 4. Programmierkurs. Datentypen. Arten von Datentypen. Wiederholung Kapitel 4. Birgit Engels, Anna Schulze WS 07/08
Kapitel 4 Programmierkurs Birgit Engels, Anna Schulze Wiederholung Kapitel 4 ZAIK Universität zu Köln WS 07/08 1 / 23 2 Datentypen Arten von Datentypen Bei der Deklaration einer Variablen(=Behälter für
MehrOrganisatorisches. drei Gruppen Gruppe 1: 10:10-11:40, Gruppe 2: 11:45-13:15 Gruppe 3: 13:20-14:50
Organisatorisches Vorlesung Donnerstag 8:35 bis 10:05 Übung drei Gruppen Gruppe 1: 10:10-11:40, Gruppe 2: 11:45-13:15 Gruppe 3: 13:20-14:50 Tutorium (Mehr oder weniger) abwechselnd Mo und Mi 10-11:30 Termine
MehrTutorium Rechnerorganisation
Woche 2 Tutorien 3 und 4 zur Vorlesung Rechnerorganisation 1 Christian A. Mandery: KIT Universität des Landes Baden-Württemberg und nationales Grossforschungszentrum in der Helmholtz-Gemeinschaft www.kit.edu
MehrInhaltsverzeichnis. Grundbegriffe der C-Programmierung Für den HI-TECH C-Compiler
Inhaltsverzeichnis Grundbegriffe der C-Programmierung 1. Grundsätzliches... 2 1.1 Darstellung von Werten... 2 1.1.1 Dezimale Zahlendarstellung... 2 1.1.2 Binäre Zahlendarstellung... 3 1.1.3 Hexadezimale
MehrAuD-Tafelübung T-B5b
6. Übung Sichtbarkeiten, Rekursion, Javadoc Di, 29.11.2011 1 Blatt 5 2 OOP Klassen Static vs. Instanzen Sichtbarkeit 3 Stack und Heap Stack Heap 4 Blatt 6 1 Blatt 5 2 OOP Klassen Static vs. Instanzen Sichtbarkeit
MehrSpeicher und Adressraum
Linearer Speicher (Adressraum) Technische Universität München Speicher und Adressraum Freie Speicherhalde (Heap) Freier Speicherstapel (Stack) Globale Variablen Bibliotheksfunktionen Laufzeitsystem Programmcode
MehrZeichendarstellung. Zeichen sind Zahlen (in C) Zeichen und switch
darstellung Arbeiten mit darstellung werden im Computer durch (kleine) Zahlen dargestellt in C können im Datentyp char gespeichert werden, dieser umfasst ein Byte und gilt als Ganzzahltyp darstellung Arbeiten
Mehr4.2 Selbstdefinierte Matlab-Funktionen 1. Teil
4.2 Selbstdefinierte Matlab-Funktionen 1. Teil 37 Ein m-file mit Namen Funktionsname.m und einer ersten Zeile der folgen Form: function Funktionsname(input1,input2,...,inputn) oder function output1=funktionsname(input1,input2,...,inputn)
MehrElementare Datentypen in C++
Elementare Datentypen in C++ bool signed/unsigned char signed/unsigned short int signed/unsigned int signed/unsigned long int (signed/unsigned long long int) float double long double void enum char Der
MehrGI Vektoren
Vektoren Problem: Beispiel: viele Variablen vom gleichen Typ abspeichern Text ( = viele char-variablen), Ergebnisse einer Meßreihe ( = viele int-variablen) hierfür: Vektoren ( = Arrays = Feld ) = Ansammlung
MehrProf. Dr. Oliver Haase Karl Martin Kern Achim Bitzer. Programmiertechnik Klassenmethoden
Prof. Dr. Oliver Haase Karl Martin Kern Achim Bitzer Programmiertechnik Klassenmethoden Motivation Programm zur Berechnung von public class Eval1 { public static void main(string[] args) { java.util.scanner
MehrC++ - Operatoren. Eigene Klassen mit neuen Funktionen
C++ - Operatoren Eigene Klassen mit neuen Funktionen Übersicht Klassen bisher Eigene Operatoren definieren 2 Bisher Durch Kapselung, Vererbung und Polymorphy können nun eigene Klassen definiert werden,
MehrAdvanced Programming in C
Advanced Programming in C Pointer und Listen Institut für Numerische Simulation Rheinische Friedrich-Wilhelms-Universität Bonn Oktober 2013 Überblick 1 Variablen vs. Pointer - Statischer und dynamischer
MehrProbeklausur: Programmierung WS04/05
Probeklausur: Programmierung WS04/05 Name: Hinweise zur Bearbeitung Nimm Dir für diese Klausur ausreichend Zeit, und sorge dafür, dass Du nicht gestört wirst. Die Klausur ist für 90 Minuten angesetzt,
Mehr