我写了一个程序,此程序有时不能正常退出,即屏幕上已经没了,但在task manager中还可以看到。因此,我想通过FindWindow查找此进程的主窗口,如果此窗口是隐藏的,则说明此进程没有正常退出。因此我想把此进程删掉,但我只知道此进程的主窗口的句柄,而无法得到此进程的id,请问如何才能得到。用PSAPI可以,但我想问问有没有更简单的方法。
解决立即送分。
解决立即送分。
解决方案 »
- 对话框加完工具栏后怎么响应?(在线等)
- 为什么复制文件时结尾的字母总被写入2遍?
- 用winsock怎么进行广域网的内网通信
- 图像显示问题!
- 如何在ATL中显示一张BMP图片
- 有关SOCKET的入门编程,请高手指点
- 又多了二三个问题(简单)
- 请问各位,在VC中有无一个消息驱动机制来监测串口数据的到达啊,而不是在WHILE(1)的死循环,或者定时器,来读取数据呢
- 谁有好的排课算法(哪怕是一点思路,在没有就哭了)
- MFC 通信层使用CAsyncSocket,使用过程中发现receive有很多缺点,也有可能是自己运用不当,求推荐,不想使用CAsyncSocket了
- 关于下拉列表框的简单问题
- 关于将一个类做成DLL得问题
コッ ハ テ・FindProcessHandleAndKill
コッハケヲトワ:クンエーソレテ軏鰈メオスエーソレヒトスフ,イ「ヌメームユ篋フノアヒタ
ー・アセ コナ:1.0
ヘ・ノネユニレ:2004/03/05
キオ サリ ヨオ:ウノケヲキオサリTRUE,キァーワキオサリFALSE
イホ ハ 1:メヤラヨキ逸ョア桄セオトエーソレオトテ﨤ニ
ニ萢・オテ・
モヲモテハセタ:
BOOL ret=FindProcessHandleAndKill("1");//イ鰈メエーソレア・簧ェ1オトエーソレ
*/BOOL FindProcessHandleAndKill(const CString &cs_WndName)
{
HWND hWnd;
DWORD ProcessID;
HANDLE hProcess; hWnd=::FindWindow(NULL, cs_WndName);
if(hWnd==NULL)//テサモミユメオスエーソレ
{
return FALSE;
}
else
{
if(GetWindowThreadProcessId(hWnd, &ProcessID)==0)//ハァーワ
{
return FALSE;
}
else
{
hProcess=OpenProcess(PROCESS_ALL_ACCESS,FALSE,ProcessID);
if(hProcess==NULL)
{
return FALSE;
}
else
{
if(TerminateProcess(hProcess, 0))
{
return TRUE;
}
else
{
return FALSE;
}
}
}
}}
/*
コッ ハ テ・FindProcessHandleAndKillInSnapShot
コッハケヲトワ:ヤレスフオトトレエ貔オマミユメオスヨクカィオトウフミフイ「ヌメームヒ・アヒタ
ー・アセ コナ:1.0
ヘ・ノネユニレ:2004/03/05
キオ サリ ヨオ:ウノケヲキオサリTRUE,キァーワキオサリFALSE
イホ ハ 1:メヤラヨキ逸ョア桄セオトウフミ・ネ・winword.exe"
ニ萢・オテ・ネ郢鉷ャメサクフミミカ犧オタヤレヤヒミミ」ャトヌテエスォヨサノアヒタメサク・ラ「メ箏トハヌユ篋ッハヨサハハモテモレWin2000マオヘウ」ャメェWin98マツスフテ釗ケモミツキセカ
モヲモテハセタ:
FindProcessHandleAndKillInSnapShot("winword.exe");
*/
BOOL FindProcessHandleAndKillInSnapShot(const CString &cs_sExeName)
{
PROCESSENTRY32 pe;
pe.dwSize=sizeof(PROCESSENTRY32);
HANDLE hProcess=NULL;
HANDLE hSnapShot;
hSnapShot=::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if(hSnapShot==NULL)
{
return FALSE;//cannot get the snapshot handle
} ::Process32First(hSnapShot, &pe); do//find the assign process name
{
CString str;
str=pe.szExeFile;
if(str.CompareNoCase(cs_sExeName)==0)
{
hProcess = ::OpenProcess(PROCESS_TERMINATE, FALSE,pe.th32ProcessID);
break;
}
}while (::Process32Next(hSnapShot, &pe));
if(hProcess==NULL)
{
//return FALSE;
}
if(::WaitForSingleObject(hProcess, 10000)!= WAIT_OBJECT_0)
{
::TerminateProcess(hProcess,0);//kill process
} ::CloseHandle(hProcess);
::CloseHandle(hSnapShot);
Sleep(5*SLEEP_TIME);
return TRUE;
}
应该这样就可以。