/*
面试(二)
开发环境:Visual Studio 2008
开发语言:C语言
要 求:阅读以下程序,口述其含义,并回答以下问题:
1.该程序输出结果有几条,并口述其原因?
2.若将WaitForMultipleObjects(MAX_THREADS,hThread,TRUE,INFINITE);
添加至
if(hThread[i]==NULL)
{
ExitProcess(i);
}
之后,输出结果有几条,并口述其原因?
若将若将WaitForMultipleObjects(MAX_THREADS,hThread,TRUE,INFINITE);
中的MAX_THREADS替换为i,输出结果有几条,并口述其原因?
3.若将Sleep(200);
添加至
if(hThread[i]==NULL)
{
ExitProcess(i);
}
之后,输出结果有几条,并口述其原因?
4.如何正确的修改其程序?
时 间:10-15分钟
得分标准:
1.第1个问题(10分)
2.第2个问题(30分)
3.第3个问题(20分)
4.第4个问题(40分)
注意:回答不出来第1个问题直接0分。
考核标准:
是否能够正确理解进程、线程的创建、等待、退出,简单的同步等。
考核小组:张一涛
批注评语:
1.由于其他线程还没有执行完,主线程就已经结束了导致输出条数不确定。
2.通过WaitForMultipleObjects函数等待hThread中的所有线程结束,导致输出结果有5条。 WaitForMultipleObjects函数的第1个参数表示,“等待的对象(线程)的数量”,那么每次循环必须等待MAX_THREADS数量。若将MAX_THREADS换为i,输出结果又可能是5条,也有可能4条(当i=0的时候,WaitForMultipleObjects函数将不等待hThread[0]中的线程,当主线程结束了,若hThread[0]线程执行完成,输出5条,若hThread[0]线程没有执行完成输出4条)。可以将MAX_THREADS换为i+1,那么输出结果一定5条。当然将WaitForMultipleObjects函数添加到for循环中这样做法并不好。
3.通过Sleep函数等待2ms,等待该线程的执行结果。这样做法输出结果有5条,但是若该线程在2ms没有计算出结果,就会导致程序的输出条数不确定。
4.可以通过等待所有线程执行完成后,再结束主线程。将以下程序添加至for循环后。
WaitForMultipleObjects(MAX_THREADS,hThread,TRUE,INFINITE);
for(i=0;i<MAX_THREADS;i++)
{
CloseHandle(hThread[i]);
}
创建线程--->等待线程执行完成--->退出线程。
*/
#include <windows.h>
#include <stdio.h>
#define MAX_THREADS 5
typedef struct _THREAD_PARAM
{
DWORD i;
DWORD dwRandom;
DWORD dwData;
}THREAD_PARAM,*LPTHREAD_PARAM;
DWORD WINAPI ThreadProc(LPVOID lpParam)
{
LPTHREAD_PARAM pData;
pData=(LPTHREAD_PARAM)lpParam;
printf("TID = %u,\t Parameters =%u,%u,%u\n",GetCurrentThreadId(),pData->i,pData->dwRandom,pData->dwData);
HeapFree(GetProcessHeap(),0,pData);
return 0;
}
void main()
{
LPTHREAD_PARAM pData;
DWORD dwThreadId[MAX_THREADS];
HANDLE hThread[MAX_THREADS];
int i;
for(i=0;i<MAX_THREADS;i++)
{
pData=(LPTHREAD_PARAM)HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,sizeof(THREAD_PARAM));
if(pData==NULL)
{
printf("HeapAlloc error\n");
ExitProcess(2);
}
pData->i=i;
pData->dwRandom=rand();
pData->dwData=100;
hThread[i]=CreateThread(NULL,0,ThreadProc,pData,0,&dwThreadId[i]);
if(hThread[i]==NULL)
{
ExitProcess(i);
}
}
}