关于 CreateEvent 和WaitForMultipleObjects以及 WaitForSingleObject 等函数的使用实例

1   创建时间句柄:CreateEvent 

HANDLE  H_Event[2];

 HANDLE  HSignal;

 H_Event[0] = ::CreateEvent(NULL,TRUE,FALSE,NULL);  

H_Event[1] = ::CreateEvent(NULL,FALSE,FALSE,NULL);

HSignal =  ::CreateEvent(NULL,FALSE,FALSE,NULL);

 关于第二个和第三个参数的说明

  第二个参数指定将事件对象创建成手动复原还是自动复原。如果是TRUE,那么必须用ResetEvent函数来手工将事件的状态复原到无信号状态。如果设置为FALSE,当事件被一个等待线程释放以后,系统将会自动将事件状态复原为无信号状态。
第三个参数 指定事件对象的初始状态。如果为TRUE,初始状态为有信号状态;否则为无信号状态。

2  WaitForSingleObject 

 函数第一个参数:事件句柄,

函数第二个参数:  超时时间,超时后向后执行,

如果为WSA_INFINITE 永不超时

如果为INFINITE,则为立即向后执行

  只检测一个事件,如果事件有信号的话就执行, 返回的参数: WAIT_OBJECT_0 (有信号),超时:WAIT_TIMEOUT

    

3   WaitForMultipleObjects 

   //第三个参数为FALSE,表示,只要有信号就可以接着执行,

//第三个参数为TRUE,表示,只有所有事件都有信号的时候才能执行下去,


下面是代码实例:

// Waitforproject.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
//#include<windef.h> //HANDLE 必须使用的头文件
#include<Windows.h> //使用事件和线程必须要有的头文件。
#include<iostream>
using namespace std;
HANDLE  H_Event[2];

HANDLE  HSignal;






DWORD WINAPI pThreadFunc(LPVOID lprama)
{
	while(1)
	{
		int nIndex = ::WaitForMultipleObjects(2, H_Event,TRUE,500); //第三个参数为TRUE,表示,只有所有事件都有信号的时候才能执行下去,

		if(nIndex == WAIT_TIMEOUT)
		{
			cout<<"Time Out"<<endl;
		}
		else if(nIndex >= WAIT_OBJECT_0 && nIndex <=WAIT_OBJECT_0+1) //就是所有事件都有信号的时候,才会执行
		{
			cout<<"ALL Event is ok " <<endl;
			break;
		}


#if 0
		int nIndex = ::WaitForMultipleObjects(2, H_Event,FALSE,500); //第三个参数为FALSE,表示,只要有信号就可以接着执行,	
		
		if(nIndex == WAIT_OBJECT_0) //第一个事件
		{
			cout<<"ONE"<<endl; //将事件的信号设置为手动退出,这样子可以做线程挂起
		}
		else if(nIndex == WAIT_OBJECT_0 +1) //第二个事件
		{
				
			cout<< "Break the Threa" <<endl;  //将事件信号设置为自动退出 ,可以做启动线程和退出线程
			break;
		}	
		else if(nIndex == WAIT_TIMEOUT) // 
		{
			cout<<"Time OUT"<<endl; 
		}

#endif	
	}



	cout<<"EXit the  Thread" <<endl;
	return 1;
	
}

DWORD WINAPI PThreadFuncSignal(LPVOID LPrama)
{
	while (1)
	{
		int nIndex = ::WaitForSingleObject(HSignal,500);
		if(nIndex == WAIT_OBJECT_0)
		{
			cout<<"break siagnel "<<endl;
			break;
		}
		cout<<"Signal"<<endl;
	}
	return 1;
}


int _tmain(int argc, _TCHAR* argv[])
{
	H_Event[0] = ::CreateEvent(NULL,TRUE,FALSE,NULL);  
	H_Event[1] = ::CreateEvent(NULL,FALSE,FALSE,NULL);
	CreateThread(NULL,0,pThreadFunc,NULL,0,NULL);  

	SetEvent(H_Event[0]);
	Sleep(3000);
	SetEvent(H_Event[1]);

#if 0
	HSignal =  ::CreateEvent(NULL,FALSE,FALSE,NULL);
	CreateThread(NULL,0,PThreadFuncSignal,NULL,0,NULL);  

	Sleep(3000);
	SetEvent(HSignal);
#endif
#if 0
	/* CreatEvent 函数。
	第二个参数指定将事件对象创建成手动复原还是自动复原。如果是TRUE,那么必须用ResetEvent函数来手工将事件的状态复原到无信号状态。如果设置为FALSE,当事件被一个等待线程释放以后,系统将会自动将事件状态复原为无信号状态。
	第三个参数 指定事件对象的初始状态。如果为TRUE,初始状态为有信号状态;否则为无信号状态。
	*/
	H_Event[0] = ::CreateEvent(NULL,TRUE,FALSE,NULL);  
	H_Event[1] = ::CreateEvent(NULL,FALSE,FALSE,NULL);


	CreateThread(NULL,0,pThreadFunc,NULL,0,NULL);  
	

	for(int i = 0; i<10;i++)
	{
		cout<<i<<endl;
		Sleep(1000);	
		if(i == 2 )
		{
			SetEvent(H_Event[0]);
		}
		else if(i == 5)
		{
			ResetEvent(H_Event[0]);

		}

	}

	SetEvent(H_Event[1]);
#endif
	system("pause:");
	return 0;
}




  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: createevent、setevent和waitforsingleobject是操作系统中用来实现线程同步和通信的函数/方法。 createevent函数用于创建一个事件对象。一个事件对象可以是自动重置的或者手动重置的。自动重置的事件对象一旦被signal(即触发)后,会自动将其状态重新设置为非信号状态;而手动重置的事件对象需要手动将其状态重置为非信号状态。createevent函数会返回一个事件对象的句柄。 setevent函数用于将一个事件对象设置为信号状态。当某个线程调用setevent函数后,事件对象的状态将变为信号状态。如果多个线程在等待该事件对象,则所有等待的线程将被唤醒。 waitforsingleobject函数用于等待一个对象的信号状态。如果对象的状态是非信号状态,则调用线程进入等待状态,直到该对象状态变为信号状态。在等待期间,线程可能会被操作系统挂起,以减少系统资源的占用。 这三个函数/方法的组合可以用来实现线程之间的同步和通信。例如,在多个线程中,可以使用createevent创建一个事件对象,并且设置为非信号状态。然后,某个线程可以调用setevent函数将该事件对象设置为信号状态。其他线程可以调用waitforsingleobject函数等待该事件对象的信号状态。当该事件对象的状态变为信号状态时,被等待的线程将被唤醒,从而实现线程间的同步和通信。 总而言之,createevent、setevent和waitforsingleobject是操作系统中用来实现线程同步和通信的函数/方法,可以帮助开发人员实现多线程程序中的同步和通信需求。 ### 回答2: createevent、setevent和waitforsingleobject是Windows操作系统中的三个同步机制函数createevent函数用于创建一个事件对象。一个事件对象是一个用来通知其他线程或者进程某个事件已经发生的同步对象。该函数返回一个事件对象的句柄,可以用来引用这个事件对象。 setevent函数用于将一个事件对象设置为信号状态。这意味着事件对象的状态被置位,其他等待该事件对象的线程将会被唤醒。setevent函数将事件对象的信号状态从非信号状态切换到信号状态。 waitforsingleobject函数用于等待一个对象的信号状态。当一个线程调用此函数时,它会进入等待状态,直到被等待的对象发出信号。对于一个事件对象来说,如果它的信号状态为非信号状态,waitforsingleobject函数将使线程进入等待状态;而如果它的信号状态为信号状态,则线程将跳过等待,并继续执行后续的代码。 通过这三个函数的配合使用,我们可以实现线程间的同步。例如,一个线程可以通过createevent函数创建一个事件对象,并将其传递给其他线程。其他线程可以通过waitforsingleobject函数等待该事件对象的信号状态。当需要时,一个线程可以通过setevent函数将该事件对象的信号状态置位,从而唤醒等待该事件对象的线程。 总结而言,createevent函数用于创建一个事件对象,setevent函数用于将事件对象设置为信号状态,waitforsingleobject函数用于等待一个对象的信号状态。这三个函数的结合使用可以实现线程间的同步机制,以便有效地管理多个线程的执行顺序和资源访问。 ### 回答3: createevent、setevent和waitforsingleobject都是操作系统中与进程间通信和同步机制相关的函数createevent函数用于创建一个事件对象。事件对象有两种状态,分别是有信号和无信号。通过createevent函数创建的事件对象默认是无信号状态。可以根据需要通过设置参数来创建手动重置或自动重置的事件对象。 setevent函数用于设置事件对象的状态为有信号。当事件对象被设置为有信号状态时,其他进程可以通过waitforsingleobject函数等待该事件的发生。 waitforsingleobject函数用于等待一个可等待对象的发生。在这里,我们可以将事件对象作为可等待对象来使用。当事件对象被设置为有信号状态时,调用waitforsingleobject函数的进程将会被唤醒并继续执行后续代码。如果事件对象处于无信号状态,调用waitforsingleobject函数的进程将会被挂起,直到事件对象状态变为有信号。 这些函数通常用于进程间的同步和通信。例如,一个进程可以创建一个事件对象,并将其设置为无信号状态。另一个进程可以通过waitforsingleobject函数等待该事件的发生。当第一个进程完成某个任务后,可以通过setevent函数将该事件设置为有信号状态,以通知第二个进程可以继续执行。 这些函数在多线程环境中也非常有用。通过使用事件对象和这些函数,可以实现线程之间的同步和协调,控制线程的执行顺序和相互通知。 总之,createevent、setevent和waitforsingleobject是操作系统中用于进程间通信和同步的重要函数,可以提供有效的线程和进程管理机制,确保程序正确、有序地执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值