arraylist
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@ -64,4 +64,5 @@ install_manifest.txt
|
|||||||
compile_commands.json
|
compile_commands.json
|
||||||
CTestTestfile.cmake
|
CTestTestfile.cmake
|
||||||
_deps
|
_deps
|
||||||
|
# ---> Extra
|
||||||
|
vgcore.*
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
project(advanced_C_standard_library C)
|
project(advanced_C_standard_library C)
|
||||||
set_property(GLOBAL PROPERTY C_STANDARD 99)
|
set_property(GLOBAL PROPERTY C_STANDARD 11)
|
||||||
cmake_minimum_required(VERSION 3.9)
|
cmake_minimum_required(VERSION 3.9)
|
||||||
include_directories(src)
|
include_directories(src)
|
||||||
file(GLOB SOURCES "src/*.c")
|
file(GLOB SOURCES "src/*.c")
|
||||||
|
|||||||
@ -1,3 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
cmake .
|
||||||
make
|
make
|
||||||
./build/test.out
|
./build/test.out
|
||||||
|
|||||||
37
src/array.c
Normal file
37
src/array.c
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
union arraylist_meta {
|
||||||
|
max_align_t dummy_align;
|
||||||
|
struct {
|
||||||
|
size_t len;
|
||||||
|
size_t cap;
|
||||||
|
size_t sizeof_one_element;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
void* arraylist_create(size_t array_size, size_t sizeof_one_element) {
|
||||||
|
union arraylist_meta *arraylist_new = malloc(array_size * sizeof_one_element + sizeof*arraylist_new);
|
||||||
|
arraylist_new->len = array_size;
|
||||||
|
arraylist_new->cap = array_size;
|
||||||
|
arraylist_new->sizeof_one_element = sizeof_one_element;
|
||||||
|
return arraylist_new+1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* arraylist_append(void *arraylist_void, void *element_void) {
|
||||||
|
char *element = element_void;
|
||||||
|
union arraylist_meta *arraylist = arraylist_void;
|
||||||
|
--arraylist;
|
||||||
|
if(arraylist->len == arraylist->cap) {
|
||||||
|
arraylist->cap = arraylist->len + 10;
|
||||||
|
arraylist = realloc(arraylist, arraylist->cap * arraylist->sizeof_one_element + sizeof *arraylist);
|
||||||
|
}
|
||||||
|
char *arraylist_char = (char*)(arraylist+1);
|
||||||
|
arraylist_char += arraylist->sizeof_one_element * arraylist->len;
|
||||||
|
for(size_t i = 0; i < arraylist->sizeof_one_element; ++arraylist_char, ++element, ++i) {
|
||||||
|
*arraylist_char = *element;
|
||||||
|
}
|
||||||
|
++arraylist->len;
|
||||||
|
return arraylist+1;
|
||||||
|
}
|
||||||
5
src/array.h
Normal file
5
src/array.h
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
#ifndef array_h
|
||||||
|
#define array_h
|
||||||
|
void* arraylist_create(size_t array_size, size_t sizeof_one_element);
|
||||||
|
void* arraylist_append(void *arraylist_void, void *element_void);
|
||||||
|
#endif
|
||||||
@ -1,4 +1,10 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include "array.h"
|
||||||
|
|
||||||
int main() {
|
int main() {
|
||||||
printf("baum\n");
|
int *int_array = arraylist_create(2, sizeof (int));
|
||||||
|
int_array[0] = 28;
|
||||||
|
int_array[1] = 20;
|
||||||
|
for(int i = 0; i < 100; ++i) int_array = arraylist_append(int_array, &i);
|
||||||
|
for(int i = 0; i < 102; ++i) printf("Index: %d Value: %d\n", i, int_array[i]);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user