首页 > 代码库 > 多线程-事件
多线程-事件
创建 CreateEvent
销毁 CloseHandle
事件变为有信号(可以使用信号) SetEvent
事件变为无信号(不可以使用信号) ResetEvent
事件的创建
HANDLECreateEvent( LPSECURITY_ATTRIBUTES lpEventAttributes, BOOL bManualReset, BOOL bInitialState, LPCTSTR lpName);
第一个参数表示安全控制,一般直接传入NULL。
第二个参数确定事件是手动置位还是自动置位,传入TRUE表示手动置位,传入FALSE表示自动置位。如果为自动置位,则对该事件调用WaitForSingleObject()后会自动调用ResetEvent()使事件变成未触发状态。打个小小比方,手动置位事件相当于教室门,教室门一旦打开(被触发),所以有人都可以进入直到老师去关上教室门(事件变成未触发)。自动置位事件就相当于医院里拍X光的房间门,门打开后只能进入一个人,这个人进去后会将门关上,其它人不能进入除非门重新被打开(事件重新被触发)。
第三个参数表示事件的初始状态,传入TRUR表示已触发。
第四个参数表示事件的名称,传入NULL表示匿名事件。
SetEvent
函数功能:触发事件
函数原型:BOOLSetEvent(HANDLEhEvent);
函数说明:每次触发后,必有一个或多个处于等待状态下的线程变成可调度状态。
ResetEvent
函数功能:将事件设为末触发
函数原型:BOOLResetEvent(HANDLEhEvent);
最后一个事件的清理与销毁
由于事件是内核对象,因此使用CloseHandle()就可以完成清理与销毁了。
#include<stdio.h>#include<process.h>#include<windows.h>int tickets=50;HANDLE g_Event;DWORD WINAPI Fun1(VOID *lp){ while(true) { WaitForSingleObject(g_Event,INFINITE); if(tickets>0) { printf("thread1 %d\n",tickets--); SetEvent(g_Event); } else { SetEvent(g_Event); break; } } return 0;}DWORD WINAPI Fun2(VOID *lp){ while(true) { WaitForSingleObject(g_Event,INFINITE); if(tickets>0) { printf("thread2 %d\n",tickets--); SetEvent(g_Event); } else { SetEvent(g_Event); break; } } return 0;}int main(){ HANDLE handle1,handle2; g_Event=CreateEvent(NULL,FALSE,FALSE,NULL); SetEvent(g_Event); handle1=CreateThread(NULL,0,Fun1,NULL,0,NULL); handle2=CreateThread(NULL,0,Fun2,NULL,0,NULL); CloseHandle(handle1); CloseHandle(handle2); Sleep(4000); CloseHandle(g_Event); return 0;}
参考:http://blog.csdn.net/morewindows/article/details/7445233
《VC++深入详解》
多线程-事件
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。