Windows内核中使用List链表来模拟FIFO操作

驱动程序经常操纵硬件,经常使用FIFO类似的缓冲数据结构,前面一篇文章介绍了使用一个CCircularFifo(http://blog.csdn.net/dijkstar/article/details/42361805)来仿真FIFO结构,内部开辟了一个大缓冲,使用固定长度数组作为缓冲区,只要缓冲区大小开的合适,完全满足工程使用需求。


FIFO的本质是一个队列,完全可以用内核中的List来实现:

//
//自定义数据结构
//
typedef struct _MYDATASTRUCT 
{
	ULONG number;	
	LIST_ENTRY ListEntry;
} MYDATASTRUCT;

//
//使用双链表模拟FIFO操作
//
#pragma INITCODE
VOID LinkListTest() 
{
	LIST_ENTRY	linkListHead;

	//初始化链表和自旋锁
	InitializeListHead(&linkListHead);


	MYDATASTRUCT *pData = NULL;	
	int i = 0;
	//
	// 模拟FIFO入队操作
	//		向链表的尾部连续插入10个元素
	//
	KdPrint(("开始从队尾插入数据, sizeof() = %d\n", sizeof(LIST_ENTRY)));
	for (i=0 ; i<10 ; i++)
	{
		pData = (MYDATASTRUCT *)ExAllocatePool(PagedPool,sizeof(MYDATASTRUCT));
		pData->number = i;
		InsertTailList(&linkListHead,&pData->ListEntry);//插入队尾
	}
	
	
	//
	// 模拟FIFO出队
	//		从链表的头部出队
	//
	KdPrint(("开始从对头出队数据\n"));
	while(!IsListEmpty(&linkListHead))
	{
		LIST_ENTRY *pEntry = RemoveHeadList(&linkListHead);//从对头出队
		pData = CONTAINING_RECORD(pEntry, MYDATASTRUCT, ListEntry);
		KdPrint(("--%d\n", pData->number));
		ExFreePool(pData);
	}
}

2015_09_25编辑:如果在应用层,使用C/C++语言,使用std::queue,std::list来模拟队列,都是很好的选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值