使用完成端口框架开发异步模块

  完成端口模型可以让我们基于传递overlapped数据的思想分解异步操作,让操作系统帮我们做线程间的数据传递。基于这个思想,可以把bsdsocket改造成异步模型,尽管这样做效率上意义不大,但对于想模拟ms完成端口都网络模型的人来说,可以小圆梦想了。
static	HANDLE	g_hiocp;



static		DWORD	WINAPI	worker(LPVOID pvd);



static	const	int	BUF_LEN	= 256;

struct myPerIoData

{

	OVERLAPPED	ov;

	char		bf[BUF_LEN];

};



int _tmain(int argc, _TCHAR* argv[])

{

	g_hiocp	= CreateIoCompletionPort(INVALID_HANDLE_VALUE,NULL,NULL,0);



	CreateThread(NULL,0,worker,NULL,0,NULL);



	BOOL	bgqcs;

	DWORD	transed;

	DWORD	comkey;

	myPerIoData*	pov;

	int		cnt	= 0;

	while (true)

	{

		transed	= 0;

		pov		= NULL;

		bgqcs	= GetQueuedCompletionStatus(g_hiocp,&transed,&comkey,(LPOVERLAPPED*)&pov,INFINITE);

		if (NULL == pov)

		{

			printf("sorry,you lost your snake/n");

			break;

		}

		printf("%s/n",pov->bf);

		delete	pov;

	}

	return 0;

}



DWORD	WINAPI worker( LPVOID pvd )

{

	int	cnt	= 0;

	while (true)

	{

		Sleep(3000);

		++cnt;

		if (cnt <= 5)

		{

			myPerIoData*	pov	= new myPerIoData;

			memset(pov,0,sizeof(myPerIoData));

			sprintf_s(pov->bf,BUF_LEN,"yes,it's snake : %d",cnt);

			PostQueuedCompletionStatus(g_hiocp,0,NULL,&pov->ov);

		}

		else

		{

			PostQueuedCompletionStatus(g_hiocp,0,NULL,NULL);

		}

	}

	return	0L;

}

  程序输出是这样的:

yes,it's snake:1

yes,it's snake:2

yes,it's snake:3

yes,it's snake:4

yes,it's snake:5

sorry,you lost your snake
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值