系统中的进程,是不断变化的,所以需要先做一个系统快照,然后中这个快照中枚举都有哪些进程。MSDN中给出了很好的例子,你可以通过查看CreateToolhelp32Snapshot函数的资料来得到这个例子。结束进程可以用函数TerminateProcess。
下面是我根据你的需要,对例子中的代码进行了小幅的修改。
BOOL GetProcessList ()
{
HANDLE hProcessSnap = NULL;
BOOL bRet = FALSE;
PROCESSENTRY32 pe32 = {0};
// 做一个系统中当前进程列表的快照
hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (hProcessSnap == INVALID_HANDLE_VALUE)
return (FALSE);
// 初始化PROCESSENTRY32结构
pe32.dwSize = sizeof(PROCESSENTRY32);
// 遍历进程列表,结构体pe32保存了进程的ID,进程名,优先级等信息,你可以利用这个结构来判断是不是你想要操作的进程。
//
if (Process32First(hProcessSnap, &pe32))
{
do
{
//在这里你可以对当前枚举到的进程进行处理,如果是你需要结果的进程,就
//HANDLE hProcess=OpenProcess(PROCESS_TERMINATE, FALSE, pe32.th32ProcessID);
//if(!hProcess)
//TerminateProcess(hProcess);
//来结束进程。
}
while (Process32Next(hProcessSnap, &pe32));
bRet = TRUE;
}
else
bRet = FALSE; // could not walk the list of processes
// Do not forget to clean up the snapshot object.
CloseHandle (hProcessSnap);
return (bRet);
}
QQ 做了保护。
一般通过EnumProcess枚举进程,检测QQexe,FindWindow检测窗口,通过GetWindowThreadprocessid得到句柄,然后Terminate进程。
或者FindWindow之后的句柄Post WM_CLOSE消息。