dequeue.h

来自「多任务下的数据结构与算法的源码」· C头文件 代码 · 共 49 行

H
49
字号
/*
 * Copyright (c) 2000-2008
 * Author: Weiming Zhou
 *
 * Permission to use, copy, modify, distribute and sell this software
 * and its documentation for any purpose is hereby granted without fee,
 * provided that the above copyright notice appear in all copies and
 * that both that copyright notice and this permission notice appear
 * in supporting documentation.  
 */

#ifndef __DEQUE_H__
#define __DEQUE_H__

#ifdef __cplusplus
extern "C" {
#endif

/* DeQue中的环形队列结构体定义 */
typedef struct DEQUEBLOCK_st {
	UINT uHead;    /* 环形队列的头部 */
	UINT uTail;	   /* 环形队列的头部 */
	UINT uMapPos;  /* 所对应map中的位置 */
	void **ppData; /* 数据指针数组 */
} DEQUEBLOCK;

/*  DeQue的结构体定义 */
typedef struct DEQUE_st {
	DEQUEBLOCK **ppMap;   /* 管理环形队列的map数组指针 */
	DEQUEBLOCK *pFirst;   /* 第一个环形队列指针 */
	DEQUEBLOCK *pLast;    /* 最后一个环形队列指针 */
	UINT uMapSize;        /* Map大小 */
	UINT uBlockSize;      /* 环形队列大小 */
} DEQUE;


DEQUE *	DeQue_Create(UINT uMapSize, UINT uBlockSize);
void	DeQue_Destroy( DEQUE *pQue, DESTROYFUNC DestroyFunc );

INT	    DeQue_InsertTail( DEQUE *pQue, void *pData );

void *  DeQue_PopHead(DEQUE *pQue);

#ifdef __cplusplus
}
#endif

#endif /* __DEQUE_H__ */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?