nginx中实现的数组比较简单,但是有个地方比较特殊
常规情况下往容器中添加元素的直观操作是写数据这个动作是在容器中实现的
nginx数组没有直接写元素到容器中操作,而是开辟好内存,把内存交给调用方,写数据交给调用试自己操作
1 数组结构 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 typedef struct { void *elts; ngx_uint_t nelts; size_t size; ngx_uint_t nalloc; ngx_pool_t *pool; } ngx_array_t ;
2 创建数组 2.1 内存开辟 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 ngx_array_t *ngx_array_create (ngx_pool_t *p, ngx_uint_t n, size_t size) { ngx_array_t *a; a = ngx_palloc(p, sizeof (ngx_array_t )); if (a == NULL ) { return NULL ; } if (ngx_array_init(a, p, n, size) != NGX_OK) { return NULL ; } return a; }
2.2 初始化 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 static ngx_inline ngx_int_t ngx_array_init (ngx_array_t *array , ngx_pool_t *pool, ngx_uint_t n, size_t size) { array ->nelts = 0 ; array ->size = size; array ->nalloc = n; array ->pool = pool; array ->elts = ngx_palloc(pool, n * size); if (array ->elts == NULL ) { return NGX_ERROR; } return NGX_OK; }
3 添加元素 3.1 单个元素添加 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 64 65 66 67 68 69 70 71 72 73 74 75 76 77 void *ngx_array_push (ngx_array_t *a) { void *elt, *new; size_t size; ngx_pool_t *p; if (a->nelts == a->nalloc) { size = a->size * a->nalloc; p = a->pool; if ((u_char *) a->elts + size == p->d.last && p->d.last + a->size <= p->d.end) { p->d.last += a->size; a->nalloc++; } else { new = ngx_palloc(p, 2 * size); if (new == NULL ) { return NULL ; } ngx_memcpy(new, a->elts, size); a->elts = new; a->nalloc *= 2 ; } } elt = (u_char *) a->elts + a->size * a->nelts; a->nelts++; return elt; }
3.2 批量添加 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 void *ngx_array_push_n (ngx_array_t *a, ngx_uint_t n) { void *elt, *new; size_t size; ngx_uint_t nalloc; ngx_pool_t *p; size = n * a->size; if (a->nelts + n > a->nalloc) { p = a->pool; if ((u_char *) a->elts + a->size * a->nalloc == p->d.last && p->d.last + size <= p->d.end) { p->d.last += size; a->nalloc += n; } else { nalloc = 2 * ((n >= a->nalloc) ? n : a->nalloc); new = ngx_palloc(p, nalloc * a->size); if (new == NULL ) { return NULL ; } ngx_memcpy(new, a->elts, a->nelts * a->size); a->elts = new; a->nalloc = nalloc; } } elt = (u_char *) a->elts + a->size * a->nelts; a->nelts += n; return elt; }
4 回收数组 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 void ngx_array_destroy (ngx_array_t *a) { ngx_pool_t *p; p = a->pool; if ((u_char *) a->elts + a->size * a->nalloc == p->d.last) { p->d.last -= a->size * a->nalloc; } if ((u_char *) a + sizeof (ngx_array_t ) == p->d.last) { p->d.last = (u_char *) a; } }