-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgeneric_fifo.c
63 lines (51 loc) · 1.47 KB
/
generic_fifo.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#define inlinetialize_linkedList \
NULL
#define linkedList_malloc(generic_ptr) \
(generic_ptr *)malloc(sizeof(generic_ptr))
typedef char *string;
typedef struct this
{
int this_value;
struct this *next;
}
linkedList;
linkedList *linkedList_append(linkedList *origin_linkedList, int value)
{
linkedList *tmp = linkedList_malloc(linkedList);
tmp->this_value = value;
tmp->next = NULL;
if (origin_linkedList != NULL)
{
linkedList *aux = origin_linkedList;
while (aux->next != NULL)
aux = aux->next;
aux->next = tmp;
// O intuído é criar um novo estado para a lista
// e não utilizar o ponteiro de referência para manipular a memória.
return origin_linkedList;
}
return tmp;
}
void linkedList_show(linkedList *origin_linkedList)
{
if (origin_linkedList != NULL)
{
printf("%d\n", origin_linkedList->this_value);
linkedList_show(origin_linkedList->next);
}
}
int main(int argc, string *argv)
{
// State Pattern > Imutabilidade
linkedList *my_linkedList = inlinetialize_linkedList;
my_linkedList = linkedList_append(my_linkedList, 1);
my_linkedList = linkedList_append(my_linkedList, 2);
my_linkedList = linkedList_append(my_linkedList, 3);
my_linkedList = linkedList_append(my_linkedList, 4);
my_linkedList = linkedList_append(my_linkedList, 5);
linkedList_show(my_linkedList);
return 0;
}