多线程中的单向链表

发布时间:2020-07-13 08:09:03 作者:Chinayu2014
来源:网络 阅读:916
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);
}


推荐阅读:
  1. golang实现单向链表的方法
  2. 复杂单向链表的复制

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

多线程 单向链栈

上一篇:Go for循环

下一篇:word文档(选择题)转换为excl表格

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》