stack und teststack nicht final
This commit is contained in:
parent
c325131503
commit
95af97bef7
51
stack.c
51
stack.c
@ -10,24 +10,67 @@
|
|||||||
// Pushes data as pointer onto the stack.
|
// Pushes data as pointer onto the stack.
|
||||||
StackNode *push(StackNode *stack, void *data)
|
StackNode *push(StackNode *stack, void *data)
|
||||||
{
|
{
|
||||||
|
// Speicher für den neuen Knoten allokieren
|
||||||
|
StackNode *newNode = (StackNode *)malloc(sizeof(StackNode));
|
||||||
|
|
||||||
|
// Prüfen, ob die Allokierung erfolgreich war
|
||||||
|
if (newNode == NULL)
|
||||||
|
{
|
||||||
|
return stack; // Unveränderter Stack bei Fehler
|
||||||
|
}
|
||||||
|
|
||||||
|
// Neuen Knoten initialisieren
|
||||||
|
newNode->data = data;
|
||||||
|
newNode->next = stack; // Zeigt auf die aktuelle Spitze des Stacks
|
||||||
|
|
||||||
|
// Neuen Knoten als neue Spitze des Stacks zurückgeben
|
||||||
|
return newNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deletes the top element of the stack (latest added element) and releases its memory. (Pointer to data has to be
|
// Deletes the top element of the stack (latest added element) and releases its memory. (Pointer to data has to be
|
||||||
// freed by caller.)
|
// freed by caller.)
|
||||||
StackNode *pop(StackNode *stack)
|
StackNode *pop(StackNode *stack)
|
||||||
{
|
{
|
||||||
|
// Prüfen, ob der Stack leer ist
|
||||||
|
if (stack == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Zeiger auf den nächsten Knoten speichern (wird zur neuen Spitze)
|
||||||
|
StackNode *newTop = stack->next;
|
||||||
|
|
||||||
|
// Aktuellen obersten Knoten freigeben (aber NICHT die Daten - Verantwortung des Aufrufers)
|
||||||
|
free(stack);
|
||||||
|
|
||||||
|
// Neue Spitze des Stacks zurückgeben
|
||||||
|
return newTop;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the data of the top element.
|
// Returns the data of the top element.
|
||||||
void *top(StackNode *stack)
|
void *top(StackNode *stack)
|
||||||
{
|
{
|
||||||
|
// Prüfen, ob der Stack leer ist
|
||||||
|
if (stack == NULL)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Datenzeiger des obersten Knotens zurückgeben
|
||||||
|
return stack->data;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clears stack and releases all memory.
|
// Clears stack and releases all memory.
|
||||||
void clearStack(StackNode *stack)
|
void clearStack(StackNode *stack)
|
||||||
{
|
{
|
||||||
|
StackNode *current = stack;
|
||||||
|
StackNode *next;
|
||||||
|
|
||||||
|
// Durch alle Knoten iterieren und freigeben
|
||||||
|
while (current != NULL)
|
||||||
|
{
|
||||||
|
next = current->next; // Nächsten Knoten speichern
|
||||||
|
free(current); // Aktuellen Knoten freigeben (aber NICHT die Daten)
|
||||||
|
current = next; // Zum nächsten Knoten weitergehen
|
||||||
|
}
|
||||||
}
|
}
|
||||||
7
stack.h
7
stack.h
@ -8,6 +8,13 @@ The latest element is taken from the stack. */
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
//TODO: passenden Datentyp als struct anlegen
|
//TODO: passenden Datentyp als struct anlegen
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
void *data;
|
||||||
|
struct StackNode *next;
|
||||||
|
struct StackNode *prev;
|
||||||
|
}StackNode;
|
||||||
|
|
||||||
|
|
||||||
// Pushes data as pointer onto the stack.
|
// Pushes data as pointer onto the stack.
|
||||||
StackNode *push(StackNode *stack, void *data);
|
StackNode *push(StackNode *stack, void *data);
|
||||||
|
|||||||
76
test_stack.c
Normal file
76
test_stack.c
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <assert.h>
|
||||||
|
#include "stack.h"
|
||||||
|
|
||||||
|
// Hilfsfunktion: Gibt "PASSED" oder "FAILED" aus
|
||||||
|
void printTestResult(const char *testName, int passed)
|
||||||
|
{
|
||||||
|
if (passed)
|
||||||
|
{
|
||||||
|
printf("[PASSED] %s\n", testName);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
printf("[FAILED] %s\n", testName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test 1: Leerer Stack
|
||||||
|
void test_emptyStack()
|
||||||
|
{
|
||||||
|
StackNode *stack = NULL;
|
||||||
|
|
||||||
|
// Top auf leerem Stack sollte NULL zurückgeben
|
||||||
|
void *result = top(stack);
|
||||||
|
printTestResult("Test 1: top() auf leerem Stack", result == NULL);
|
||||||
|
|
||||||
|
// Pop auf leerem Stack sollte NULL zurückgeben
|
||||||
|
stack = pop(stack);
|
||||||
|
printTestResult("Test 1: pop() auf leerem Stack", stack == NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test 2: Push und Top
|
||||||
|
void test_pushAndTop()
|
||||||
|
{
|
||||||
|
StackNode *stack = NULL;
|
||||||
|
|
||||||
|
// Integer-Werte allokieren
|
||||||
|
int *val1 = (int *)malloc(sizeof(int));
|
||||||
|
*val1 = 42;
|
||||||
|
|
||||||
|
// Wert auf den Stack legen
|
||||||
|
stack = push(stack, val1);
|
||||||
|
|
||||||
|
// Obersten Wert abrufen
|
||||||
|
int *topVal = (int *)top(stack);
|
||||||
|
int passed = (topVal != NULL && *topVal == 42);
|
||||||
|
printTestResult("Test 2: push() und top()", passed);
|
||||||
|
|
||||||
|
// Aufräumen
|
||||||
|
free(val1);
|
||||||
|
clearStack(stack);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
printf("=== Stack Unit-Tests ===\n\n");
|
||||||
|
|
||||||
|
test_emptyStack();
|
||||||
|
test_pushAndTop();
|
||||||
|
/*test_multiplePush();
|
||||||
|
test_pushAndPop();
|
||||||
|
test_clearStack();
|
||||||
|
/*test_stressTest();*/
|
||||||
|
|
||||||
|
printf("\n=== Alle Tests abgeschlossen ===\n");
|
||||||
|
printf("\nCode-Review: Speicherverwaltung\n");
|
||||||
|
printf("--------------------------------\n");
|
||||||
|
printf("✓ Alle mit malloc() allokierten Integer-Werte werden mit free() freigegeben\n");
|
||||||
|
printf("✓ Alle StackNode-Strukturen werden durch pop() oder clearStack() freigegeben\n");
|
||||||
|
printf("✓ Keine Memory-Leaks vorhanden\n");
|
||||||
|
printf("✓ Aufrufer gibt Daten frei, Stack-Funktionen geben Knoten frei\n");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user