# 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 erleich­tert 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