47 lines
2.4 KiB
Markdown
47 lines
2.4 KiB
Markdown
# stack.h
|
||
*Aufgabe: passender Datentyp für ein Listenelement als struct anlegen*
|
||
|
||
``` c
|
||
typedef struct Node
|
||
{
|
||
void *data;
|
||
struct Node* next;
|
||
} StackNode;
|
||
```
|
||
|
||
* **typedef** nicht zwingend notwendig, aber erleichtert später den Aufruf: `StackNode` vs `struct stackNode`
|
||
* **Zeiger data** zeigt auf in Liste gespeicherten Wert
|
||
* **Zeiger auf Node struct**, der auf das folgende Node zeiget (oder NULL ist, wenn kein folgendes vorhanden)
|
||
* für jedes struct dieses Typs, dass wir später in den Stack.c Funktionen erstellen muss Speicher manuell zugewiesen werden!
|
||
|
||
|
||
# stack.c
|
||
|
||
### push:
|
||
*neues Element oben auf die Liste legen*
|
||
* Sicherheits-Überprüfung: falls übergebener Pointer für Daten kein Ziel hat (data = NULL) => alle unten beschriebenen Schritte werden übersprungen, Stack- Pointer wird unverändert zurück gegeben
|
||
* Listenelement erstellen: (Standard Ablauf für Structs)
|
||
* Pointer initialisieren
|
||
* mit malloc an diesem Ort im Speicher in der richtigen Größe reservieren (hier Größe eines Listenelements)
|
||
* Speicher kann genutzt werden
|
||
* data wird gespeichert
|
||
* next passend setzen, entweder zuvor oberstes Element oder keines, wenn Liste leer war
|
||
* stack-Pointer auf neues, oberstes Listetenelement zeigen lassen
|
||
|
||
### pop:
|
||
*oberstes Element von Liste löschen*
|
||
* Sicherheits-Überprüfung: wenn Stack schon leer ist wird nichts entfernt (Stack = NULL bedeutet kein erstes Element existiert) - sonst würde nicht reservierter Speicher freigegeben
|
||
* müssen alle Zeiger auf das Element ändern und den Speicher Freigeben - damit ist alles entfernt:
|
||
* zum Löschen wird Speicher am Ort des stack-Zeigers freigegeben - damit ist das oberste Element weg
|
||
* zuletzt wird der Stack-Zeiger neu gesetzt, um auch alle Pointer, die noch auf das gelöschte Element zeigen zu aktuallisieren
|
||
|
||
### top:
|
||
*gibt Daten-Zeiger des obersten Elements zurück*
|
||
* Sicherheits-Überprüfung: existiert ein oberstes Element überhaupt? sonst würde man beim Versuch data auszulesen auf überhaupt nicht bzw anders zugewiesenen Speicher zugreifen!
|
||
* zur normalen Ausgabe wird einfach der Zeigerwert der data-Variable des oberster Stackelements zurückgegeben
|
||
|
||
### clear stack:
|
||
*die Liste leeren inklusive Speicherfreigabe*
|
||
* Funktionsprinzip: so lange das oberste Element mit pop-funktion entfernen, bis die Liste leer ist
|
||
* da pop erkennt, wenn Liste leer und dann den Stack-Pointer NULL setzt dient das als Schleifenvariable
|