1 Star 4 Fork 3

eraser_git/环形队列模块

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
queue.h 1.71 KB
一键复制 编辑 原始数据 按行查看 历史
yiweijiao1991 提交于 2019-12-18 13:41 . 增加windows系统的兼容
#ifndef __QUEUQ_H__
#define __QUEUE_H__
#if !defined(WIN32)
#include <pthread.h>
#else
#include <Windows.h>
#endif
#define QUEUE_MAX_COUNT 10
typedef struct queue_t{
void *data_ptr[QUEUE_MAX_COUNT];//队列数据指针
int head;//队首
int tail;//队尾
int count;//队列中的数据
int data_size;//每个数据的大小
#if !defined(WIN32)
pthread_mutex_t mtx;//互斥锁
#else
CRITICAL_SECTION mtx;
#endif
} queue_t;
/*
函数名称:
init_queue
说明:
初始化环形队列
参数:
queue[in/out]:环形队列指针
data_size[in]:唤醒队列每个块的内存大小(最好使用sizeof计算)
返回值:
-1参数错误
0成功
*/
int init_queue(queue_t * queue,int data_size);
/*
函数名称
free_queue
说明
释放环形队列资源
参数
queue[in]:环形队列指针
返回值
-1参数错误
0成功
*/
int free_queue(queue_t * queue);
/*
函数名称:
pop_queue
说明
数据出队,将数据复制到data指向的存储空间
参数
queue[in]:循环队列指针
data[out]:数据存储取指针
返回值
-1参数错误
-2队列为空
-3出队失败,对列内存错误
0 成功
*/
int pop_queue(queue_t * queue,void *data);
/*
函数名称:
push_queue
说明
数据入队,将data指针空间的数据拷贝到队列中
参数
queue[in]:队列指针
data[in]:数据指针
返回值
-1参数错误
-2队列已满
-3队列内存错误
0成功
*/
int push_queue(queue_t * queue,void *data);
/*
函数名称:
empty_queue
说明
清空环形队列的内容
参数
queue[in]:队列指针
返回值
-1参数错误
0 成功
*/
int empty_queue(queue_t * queue);
#endif
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/eraser_git/ring_queue_module.git
git@gitee.com:eraser_git/ring_queue_module.git
eraser_git
ring_queue_module
环形队列模块
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385