一道迅雷多线程编程题

题目要求:

编写一个程序,开启3个线程,这3个线程的ID分别为ABC,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示;如:ABCABC.依次递推


分析:

本问题为线程同步问题。申请三个事件对象保持三个线程同步(先子线程A,再线程B,然后线程C)!

显然事件对象很适合做。

SetEvent(),将事件对象设置为有信号

ResetEvent(),将事件对象设置为无信号

WaitForSingleObject(),有信号才能被申请。

a)子线程A先执行,则子线程A的事件对象必须有信号,而其他线程必须先无信号(等待线程A执行完后开启)!

b)子线程A执行完一次后,则将子线程A事件对象无信号,将线程B事件对象设置为有信号

c)线程B执行完一次后,则将线程B事件对象无信号,将子线程C事件对象有信号(准备被申请并执行子线程C)

d)如此往复10次上诉行为。


具体代码如下:

#include      
#include      

unsigned int __stdcall Fun(void *pPM);

//线程个数  
const int THREAD_NUM = 3;
//循环次数  
const int LOOP = 10;
//互斥事件  
HANDLE g_hThreadEvent[THREAD_NUM];

int main()
{
	HANDLE hdl[THREAD_NUM];

	for (int i = 0; i < THREAD_NUM; i++)
		g_hThreadEvent[i] = CreateEvent(NULL, TRUE, FALSE, NULL);
	
	//将线程编号作为线程参数传进去,先转换为指针,再转换为整形,  
	for (int i = 0; i < THREAD_NUM; i++)
		hdl[i] = (HANDLE)_beginthreadex(NULL, 0, Fun, (int*)i, 0, NULL);
	
	SetEvent(g_hThreadEvent[0]);//线程0,触发为有信号,可以执行了
	Sleep(1000);
	//让线程进入等待状态,保证子线程已全部运行结束  
	WaitForMultipleObjects(THREAD_NUM, hdl, TRUE, INFINITE);

	for (int i = 0; i < THREAD_NUM; i++)
	{
		CloseHandle(hdl[i]);
		CloseHandle(g_hThreadEvent[i]);
	}
	getchar();
	return 0;
}

unsigned int __stdcall Fun(void *pPM)
{
	int num = (int )pPM;
	for (int i = 0; i< LOOP; i++)//10
	{
		WaitForSingleObject(g_hThreadEvent[num], INFINITE);//等待g_hThreadEvent[num]有信号,若无将一直等待
		ResetEvent(g_hThreadEvent[num]);
		printf("%c", 'A'+ num);
		SetEvent(g_hThreadEvent[(num + 1) % THREAD_NUM]);//将下一个线程设置为有信号!
	}
	return 0;
}


一道迅雷多线程编程题_第1张图片

参考资源:

【1】如何向线程函数传递多个参数?

【2】 http://blog.csdn.net/lilien1010/article/details/8118735


你可能感兴趣的:(多线程,C++,面试,mfc,编程,VC++)