标题: 一个简单的C语言循环缓冲队列实现 [打印本页]

作者: jizhongbiao    时间: 2021-9-22 15:10
标题: 一个简单的C语言循环缓冲队列实现
typedef struct {
    u8 head;
    u8 tail;
    u8 len;
}ListSt;

#define UART_BUFF_SIZE 100
u8 g_listBuff[UART_BUFF_SIZE];
ListSt g_uartListTcb = {0};

void AddItem(u8 dat)
{
    if (g_uartListTcb.len == UART_BUFF_SIZE)
    {
        return;
    }
    g_listBuff[g_uartListTcb.tail] = dat;
    g_uartListTcb.len++;
    (g_uartListTcb.tail++) %= UART_BUFF_SIZE;
}

u8 GetItem(void)
{
    u8 ret;
    if (GetItem() == 0)
    {
        return;
    }
    ret = g_listBuff[g_uartListTcb.head];
    g_uartListTcb.head++;
    g_uartListTcb.head %= UART_BUFF_SIZE;
    g_uartListTcb.len--;
    return ret;
}

u8 GetItemRemain(void)
{
    return g_uartListTcb.len;
}



作者: shumivan    时间: 2021-10-12 10:56
你应该定义多个结构体BUF去进行循环,现在还不是很完美
作者: jizhongbiao    时间: 2021-11-8 14:01
shumivan 发表于 2021-10-12 10:56
你应该定义多个结构体BUF去进行循环,现在还不是很完美

请问,大概什么思路?多加一个buf的好处是什么。
作者: genesis_2012    时间: 2021-11-12 23:18
GetItem需要优化,这里不管队列是不是空都有返回值




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1