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(),在里面作出规定:只有在完成任务后才能退出。
希望毁差棚能帮到纤则你
return就是跳出函数,意思是给函数绝铅桥一个返并猛回值 比如 void aa() { return//返回值为空激磨 } int aa() { return 1} char aa() { return 'a'}这个地方改改// 主消息循环:
while (GetMessage(&msg, NULL, 0, 0))
{
............TranslateMessage(&msg)
............DispatchMessage(&msg)
}
LZ 在裂改网上搜索一下程序关闭的流程。
窗口先销毁,释放资源,同时在线程消息队列中加入WM_QUIT消息,而此消息是没和窗口相关的。正源扮
窗口destroywindow后就不存在了,这时候向线程发送的关闭消息就没法处理举灶,也就在getmessage步限入了死循环
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)