nginx 源码学习笔记(九)——基本容器——queue

src/core/ngx_queue.{c|h}实现了一个队列的操作逻辑,队列的基本结构为一个双向队列

基础数据结构为:

  1. typedef struct ngx_queue_s  ngx_queue_t;  
  2.   
  3. struct ngx_queue_s {  
  4.     ngx_queue_t  *prev;  
  5.     ngx_queue_t  *next;  
  6. };  

根据数据结构可以发现,nginx的队列操作和结构只进行指针操作,不负责节点内容空间的分配和保存,所以在定义自己的队列节点的时候,需要自己定义数据结构以及分配空间,并包含一个ngx_queue_t类型的成员,需要获得原始的数据节点的时候,需要使用ngx_queue_data宏:

  1. src/core/ngx_queue.h  
  2. #define ngx_queue_data(q, type, link)  (type *) ((u_char *) q - offsetof(type, link))  

另外,整个queue结构中包含一个sentinel哨兵节点,他指向队列的头和尾。


看了下queue的源码发现实现部分只有两个方法:

  1. ngx_queue_t * ngx_queue_middle(ngx_queue_t *queue) //查找中间的queue  
  2. void ngx_queue_sort(ngx_queue_t *queue, ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *)) //貌似是插入排序,//这里没有多看  


ngx_queue_init初始化队列

ngx_queue_empty清空节点中在某一个节点之前的所有节点

ngx_queue_insert_head插入一个节点在指定节点之后

ngx_queue_insert_after插入一个节点在指定节点之后
ngx_queue_insert_tail 插入一个节点在指定节点之前
ngx_queue_head 得到节点的下一个节点
ngx_queue_next 得到节点的下一个节点
ngx_queue_last 得到节点的上一个节点
ngx_queue_prev 得到节点的上一个节点
ngx_queue_sentinel 得到当前的节点
ngx_queue_remove 删除队列中的某一个节点
ngx_queue_data 得到队列某一节点的数据
ngx_queue_split
ngx_queue_add
ngx_queue_middle
ngx_queue_sort

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值