
HANDLE hProcessSnap
TCHAR ProcessName[]="Application.exe"
DWORD ProcessID=0x00
hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0)
if(hProcessSnap==INVALID_HANDLE_VALUE)
{
printf("列举进程失败\n")
return
}
PROCESSENTRY32 pe32
pe32.dwSize = sizeof(pe32)
BOOL bProcess = Process32First(hProcessSnap, &pe32)
TCHAR buff[1024]
while(bProcess)
{
if(strcmp(ProcessName,pe32.szExeFile)==0)
{
ProcessID= pe32.th32ProcessID
break
}
memset(buff, 0x00, 1024)
bProcess=Process32Next(hProcessSnap, &pe32)
}
if(ProcessID==0)
{
printf("没有找到进程%s", ProcessName)
return
}
然后把ProcessID作为参数,按照下面这篇文章所说的方法得到该进程的主窗口句柄:http://www.vckbase.com/document/viewdoc/?id=404
假庆码设得到的句柄为pWnd,然后直接向该窗口发送关闭消息即可:
pWnd->PostMessage(WM_CLOSE)//这种方法是让目标进程自己退出,所以属于安全退出
一般程序会默认处理WM_CLOSE消息,所以当向一个进程的主窗口窗口发送WM_CLOSE消息时就可以关闭该进程,不信你可以试试用下面的代码向任务管理器发送WM_CLOSE消息:
HWND hwnd = ::FindWindow("#32770","Windows 任务管理器")
if(hwnd)
{
::PostMessage(hwnd , WM_CLOSE, 0, 0)
}
要想让被关闭程序在退出之前完成当前任务,则只有在被关闭程序中添加WM_CLOSE的消息函数OnClose(),在里面作出规定:只有在完成任务后才能退出。
希望毁差棚能帮到纤则你
C/C++有个函迟升笑数:system("cmd_command")在DOS下执行cmd_command命令,结束笑宏进程:system("taskkill /码含im ._cache_工具.exe")
就这一条,不知道满足你的要求不。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)