Libuv-queue.h使用

本文详细介绍了如何在C语言中使用libuv-queue.h库实现队列,包括队列的初始化、数据插入、遍历和删除操作。作者提供了代码示例以展示这些功能的实际应用。
摘要由CSDN通过智能技术生成

说明

本文主要是个人在工作中使用到libuv-queue.h中的队列实现,在这里记录下常见的使用方式,并不对queue具体实现原理做剖析。

使用示例

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "queue.h"

typedef struct myNode_s
{
    QUEUE queue;
    int val;
} myNode_t;

typedef struct audit_s {
    QUEUE req_queue;
    QUEUE resp_queue;
} audit_t;

/**
 * @brief 遍历队列并删除所有节点
*/
void clear_queue(QUEUE *queue)
{
    while(!QUEUE_EMPTY(queue)) {
        // 每次删除头节点
        QUEUE *q = QUEUE_HEAD(queue);
        QUEUE_REMOVE(q);
        myNode_t *req_node = QUEUE_DATA(q, myNode_t, queue);
        free(req_node);
    }
}

/**
 * @brief 用于遍历队列,不能在其中插入删除节点的操作
*/
void travel_queue(QUEUE *queue)
{
    myNode_t *req_node;
    QUEUE *q;
    QUEUE_FOREACH(q, queue) {
        req_node = QUEUE_DATA(q, myNode_t, queue);
        printf("val: %d\n", req_node->val);
    }
}

int main()
{
    audit_t *audit = malloc(sizeof(audit_t));
    QUEUE_INIT(&audit->req_queue);
    QUEUE_INIT(&audit->resp_queue);

    // 插入数据
    for (int i = 0; i < 10; i++) {
        myNode_t *req_node = malloc(sizeof(myNode_t));
        req_node->val = i;
        QUEUE_INSERT_TAIL(&audit->req_queue, &req_node->queue);
        // printf("Inserted req value: %d\n", i);
        myNode_t *resp_node = malloc(sizeof(myNode_t));
        resp_node->val = i + 10;
        QUEUE_INSERT_TAIL(&audit->resp_queue, &resp_node->queue);
        // printf("Inserted resp value: %d\n", i + 10);
    }

    // test travel queue
    travel_queue(&audit->req_queue);

#if 0
    // test clear queue
    clear_queue(&audit->req_queue);
    if (!QUEUE_EMPTY(&audit->req_queue)) {
        printf("Error: req_queue is not empty after clear\n");
    } else {
        printf("req_queue is empty after clear\n");
    }
#endif

#if 0
    // 审计出队列
    printf("Auditing request queue...\n");
    while (!QUEUE_EMPTY(&audit->req_queue) && !QUEUE_EMPTY(&audit->resp_queue)) {
        QUEUE *q = QUEUE_HEAD(&audit->req_queue);
        QUEUE_REMOVE(q);
        myNode_t *node = QUEUE_DATA(q, myNode_t, queue);

        QUEUE *q2 = QUEUE_HEAD(&audit->resp_queue);
        QUEUE_REMOVE(q2);
        myNode_t *node2 = QUEUE_DATA(q2, myNode_t, queue);

        printf("Request value: %d, Response value: %d\n", node->val, node2->val);
        free(node);
        free(node2);
    }
#endif

    return 0;
}

总结

上述示例主要涉及以下几个部分:

  • 队列初始化
  • 队列数据插入
  • 队列遍历获取节点值
  • 删除队列
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值