47 lines
2.4 KiB
Markdown
Raw Permalink Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 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