用CreateToolhelp32Snapshot/Process32First/Process32Next API枚举系统进程

来源:互联网 发布:mac提取dsdt 编辑:程序博客网 时间:2024/05/16 07:48

/*********************************************************************
用CreateToolhelp32Snapshot/Process32First/Process32Next API枚举系统进程
在很多情况下需要对系统的进程进行操作,方法有很多种但最常用的是
CreateToolhelp32Snapshot/Process32First/Process32Next 一系列API使现结束进程使用
TerminateProcess使现
下面的函数可以使现对进程的枚举:
**************************************************************************/

int ProcessList()
{
       PROCESSENTRY32 pe32;
       pe32.dwSize=sizeof(pe32);
       int count=0;
 
       HANDLE hProcessSnap=::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);
 
       if(hProcessSnap==INVALID_HANDLE_VALUE)
       {
              printf("CreateToolhelp32Snapshot调用失败!");
              return -1;
       }
 
       BOOL bMore=::Process32First(hProcessSnap,&pe32);
      
       printf("%20s/t%10s/n","进程名","PID");
       printf("====================================/n");
       while(bMore)
       {
              count++;
              printf("%20s/t%10d/n",pe32.szExeFile,pe32.th32ProcessID);
              bMore=::Process32Next(hProcessSnap,&pe32);
       }
 
       ::CloseHandle(hProcessSnap);
 
       printf("====================================/n");
       printf("/n当前系统进程数为:%d/n",count);
 
       return 0;
}

//结束进程可以使用下面的函数:(使现其中dwid为想要结束的进程ID可通过列进程的函数得到)
 
int TerminateProcessFromId(DWORD dwId)
{
       BOOL bRet=FALSE;
 
       HANDLE hProcess=::OpenProcess(PROCESS_ALL_ACCESS,FALSE,dwId);
       if(hProcess!=NULL)
       {
              bRet=::TerminateProcess(hProcess,0);
       }
 
       ::CloseHandle(hProcess);
 
       if(bRet)
              printf("%d 进程结束成功....../n/n/n/n",dwId);
       else
              printf("%d 进程结束失败....../n/n/n/n",dwId);
 
       return 0;
}

//与进程相关的操作通常还要提升权限
//由于代码相对比较简单,所以就没有更多的文字说明,关键的函数加了注释,其实使用时直接调用就OK了.


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/zhoubaocun/archive/2007/12/30/2004650.aspx