代码拉取完成,页面将自动刷新
#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
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。