Binary Array is a struct array for your to add index for struct field member and it can be binary search When the field been indexed, it will auto sorted while inserting new node, please make sure the field has value pre-allocated memory.
Every struct have to be pre-allocated and value setted before push into binary array.
- this lib mostly target for big datatable searching on cache.
- gcc/clang/llvm-gcc
- goto root directory
- gcc binary_array.c main.c -otest
- ./test
- arg0=The size of array
- arg1=number of index will be created
- return bin_array (root_array)
- arg0=root_array
- arg1=the struct name
- arg2=the field name
- arg3=the cmp_function(built in given, please see demo for details)
- return 1 if successful, 0 if fail created
- arg0=root array
- arg1=pre-allocated node
- return 1 if successful, 0 if fail pushed
- it is push more than 1 elements at one time by given a array node.
- arg0=root array
- arg1=pre-allocated node array
- arg2=number of element does node array have
- return 1 if successful, 0 if fail pushed
- it is binary search if key matched, it direct return the pointer which point to the node(do not free the node).
- arg0=root array
- arg1=struct name
- arg2=field name
- arg3=key for search
- return the pointer pointed to the node
- it is binary search if every node matched to the key
- arg0=root array
- arg1=struct name
- arg2=field name
- arg3=key for search
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is binary search if every node lower than the key
- arg0=root array
- arg1=struct name
- arg2=field name
- arg3=key for search
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is binary search if every node greater than the key
- arg0=root array
- arg1=struct name
- arg2=field name
- arg3=key for search
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is binary search more than 1 eq, similar to IN query in sql, it so far can up to 10 key search at the same time.
- arg0=root array
- arg1=struct name
- arg2=field name
- arg3=key1 for search
- arg4=key2 for search
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is union rs1 and rs2, and return the merged result.
- arg0=result set 1
- arg1=result set 2
- arg2=boolean to tell whether want to free rs1 and rs2 after new merged result created
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is finding the intersection value between rs1 and rs2, and return the merged result.
- arg0=result set 1
- arg1=result set 2
- arg2=boolean to tell whether want to free rs1 and rs2 after new merged result created
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- it is just appending the result, .
- arg0=result set 1
- arg1=result set 2
- arg2=boolean to tell whether want to free rs2 after new merged result created
- return the result set(bin_array_rs) and need to be free after use, see demo for details
- you can resort the result with your customized compare function, .
- arg0=result set 1
- arg1=result set 2
- arg2=boolean to tell whether want to free rs2 after new merged result created
- return nothing
- free the result set
- arg0=result set
- it is clear all the value but still remaining the array schema and indexed, for the purpose of reload/reset the data.
- arg0=root array
- arg1=free node function, to create a free node function to free the node when destroy array
- return nothing
- it is destrying the root array
- arg0=root array
- arg1=free node function, to create a free node function to free the node when destroy array
- return nothing
void bin_array_safety_swap(bin_array_t **curr, bin_array_t *new_a, free_node_fn free_node_fn, unsigned int buffer_time_mic_sec)
- It is making hazard ptr to swap new array into curr array safety,
- arg0=curr array dereference
- arg1=new array to replace curr array
- arg2=free node function, to create a free node function to free the node when destroy old array
- arg3=the buffer time for old array going to be freed, the purpose for current thread may still using old array with specific of time
- return nothing
- it means the value must allocate memory before push into the array. The buffer will keeping the same value until you destroy the array, it will be freed