ngx_array
对应的文件为 core/ngx_array.{c|h}
ngx_array是nginx内部封装的使用 ngx_pool_t对内存池进行分配的数组容器,其中的数据是在一整片内存区中连续存放的。更新数组时只能在尾部压入1个或多个元素。
数组的实现结构为
- struct ngx_array_s {
- void *elts;
- ngx_uint_t nelts;
- size_t size;
- ngx_uint_t nalloc;
- ngx_pool_t *pool;
- };
其中 elts 为具体的数据区域的指针, nelts 为数组实际包含的元素数量, size为数组单个元素的大小, nalloc为数组容器预先(或者重新)分配的内存大小, pool 为分配基于的内存池
常用的操作有
- // 创建一个新的数组容器
- ngx_array_t *ngx_array_create(ngx_pool_t *p, ngx_uint_t n, size_t size);
- // 销毁数组容器
- void ngx_array_destroy(ngx_array_t *a);
- // 将新的元素加入数组容器
- void *ngx_array_push(ngx_array_t *a);
- void *ngx_array_push_n(ngx_array_t *a, ngx_uint_t n); //返回n个元素的指针
这里需要注意的是,和之前的ngx_pool_cleanup_add一样, ngx_array_push只是进行内存分配的操作,我们需要对返回的指针指向的地址进行赋值等操作来实现实际数组值的添加。
具体一点的push操作的实现为,
- 首先判断 nalloc是否和nelts相等,即数组预先分配的空间已经满了,如果没满则计算地址直接返回指针
- 如果已经满了则先判断是否我们的pool中的当前链表节点还有剩余的空间,如果有则直接在当前的pool链表节点中分配内存,并返回
- 如果当前链表节点没有足够的空间则使用ngx_palloc重新分配一个2倍于之前数组空间大小的数组,然后将数据转移过来,并返回新地址的指针
下面是一个array的例子:
demo/basic_types/array_and_hash.c
- #include <stdio.h>
- #include "ngx_config.h"
- #include "ngx_conf_file.h"
- #include "nginx.h"
- #include "ngx_core.h"
- #include "ngx_string.h"
- #include "ngx_palloc.h"
- #include "ngx_array.h"
- volatile ngx_cycle_t *ngx_cycle;
- void
- ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
- const char *fmt, ...)
- {
- }
- int main()
- {
- ngx_pool_t* pool;
- ngx_array_t* arr;
- int n;
- int* ele;
- pool = ngx_create_pool(4000, NULL);
- arr = ngx_array_create(pool, 10, sizeof(ngx_uint_t));
- for (n=0; n < 5; n++) {
- ele = (int*) ngx_array_push(arr);
- *ele = n;
- printf("new element %d added\n", n);
- }
- printf("arr->nelts is %d, arr->nalloc = %d\n", arr->nelts, arr->nalloc);
- for (n=5; n < 15; n++) {
- ele = (int*) ngx_array_push(arr);
- *ele = n;
- printf("new element %d added\n", n);
- }
- printf("arr->nelts is %d, arr->nalloc = %d\n", arr->nelts, arr->nalloc);
- ngx_array_destroy(arr);
- ngx_destroy_pool(pool);
- return 0;
- }
编译运行
- gcc -c -O -pipe -O -W -Wall -Wpointer-arith -Wno-unused-parameter -Wunused-function -Wunused-variable -Wunused-value -Werror -g -I ../../../objs/ -I ../../os/unix array_and_hash.c -I../../core/ -I../../event/ -I../../os/ -o array_and_hash.o
- gcc -o array_and_hash array_and_hash.o ../../../objs/src/core/ngx_{string,palloc,array}.o ../../../objs/src/os/unix/ngx_alloc.o -lcrypt -lpcre -lcrypto -lz
- ./array_and_hash
输出
- new element 0 added
- new element 1 added
- new element 2 added
- new element 3 added
- new element 4 added
- arr->nelts is 5, arr->nalloc = 10
- new element 5 added
- new element 6 added
- new element 7 added
- new element 8 added
- new element 9 added
- new element 10 added
- new element 11 added
- new element 12 added
- new element 13 added
- new element 14 added
- arr->nelts is 15, arr->nalloc = 15
阅读(1624) | 评论(0) | 转发(0) |