资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

多线程中的单向链表

typedef struct MsgData
{
	SLIST_ENTRY  NextEntry;//下一个结点
	INT  ID;
	char buff[20];
}STDATA,*PSTDATA;

void CtestThreadDlg::OnBnClickedButton17()
{
	PSLIST_ENTRY    pListFirstItem,pListItem;
	PSLIST_HEADER   pHead;

	//创建头结点
	pHead = (PSLIST_HEADER)_aligned_malloc(sizeof(SLIST_HEADER),
	                                MEMORY_ALLOCATION_ALIGNMENT);
	//初始化头结点
	InitializeSListHead(pHead);

	//新结点数据
	PSTDATA stPdata = (PSTDATA)_aligned_malloc(sizeof(STDATA), 
	                                MEMORY_ALLOCATION_ALIGNMENT);
	stPdata->ID = 1200;
	strcpy_s(stPdata->buff, 20,"message");
	//添加到队列中,从头添加节点,返回前一个节点
	pListFirstItem = InterlockedPushEntrySList(pHead, &stPdata->NextEntry);

	
	pListItem = InterlockedPopEntrySList(pHead);//从头部取出数据
	PSTDATA pData = (PSTDATA)pListItem;
	CString str(pData->buff);
	TRACE(str+_T("\n"));
	_aligned_free(pListItem);//释放内存

	InterlockedFlushSList(pHead);
	pListItem = InterlockedPopEntrySList(pHead);
	if (pListItem == NULL)
	{
		TRACE(_T("已清空\n"));
	}
	_aligned_free(pHead);
}

分享名称:多线程中的单向链表
当前网址:http://cdkjz.cn/article/gcigho.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220