快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

多线程中的单向链表

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://6mz.cn/article/gcigho.html

其他资讯