加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C++扫描系统进程代码

发布时间:2020-12-16 07:43:56 所属栏目:百科 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 自己一直想做一个和windows资源管理器一样的程序,所以看了一下如何列举系统的所有进程。主要用到几个函数 CreateToolhelp32Snapshot,Process32First

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

自己一直想做一个和windows资源管理器一样的程序,所以看了一下如何列举系统的所有进程。主要用到几个函数
CreateToolhelp32Snapshot,Process32First,Process32Next和一个结构体PROCESSENTRY32。其中用法可以看百度百科或MSDN
#include <windows.h> 
#include <tlhelp32.h> 
#include <tchar.h> 
#include <stdio.h> 
#include<iostream> 
using namespace std; 
int main() 
{ 
    HANDLE hProcessSnap; 
    HANDLE hProcess; 
    PROCESSENTRY32 pe32;//用来存储进程的相关信息 
    DWORD dwPriorityClass;// 
   
    //建立进程快照 
    hProcessSnap = CreateToolhelp32Snapshot( TH32CS_SNAPPROCESS,0);//获得系统进程的快照 
   
    if(hProcessSnap == INVALID_HANDLE_VALUE) 
    { 
        cout<<"快照创建失败"<<endl; 
        return 0; 
    } 
    pe32.dwSize = sizeof(PROCESSENTRY32); 
    if(Process32First( hProcessSnap,&pe32) == NULL) 
    { 
        cout<<"error"<<endl; 
        CloseHandle(hProcessSnap); 
   
    } 
    int i = 0; 
    do{ 
        cout<<"------------"<<i++<<"个进程------------------------"<<endl; 
        //cout<<" name : "<<pe32.szExeFile<<endl; 
        _tprintf( TEXT("nPROCESS NAME: %s"),pe32.szExeFile ); 
        cout<<endl; 
        cout<< "Process ID = "<< pe32.th32ProcessID <<endl; 
        cout<< "Thread count = "<<pe32.cntThreads <<endl;  
        cout<< "Parent process ID = "<< pe32.th32ParentProcessID <<endl;;  
        cout<< "Priority base = "<< pe32.pcPriClassBase <<endl;  
    }while( Process32Next( hProcessSnap,&pe32) ); 
    return 0; 
   
} 
 

当然,上面程序是我从一个程序中摘出来的,这是源程序,忘了引用的哪了,如果作者看到,请告知引用地址。

这个程序实现了对系统进程,单个进程和线程的快照,主要还是拿几个函数,有时间的话做一个可视化的,和大家分享
#include <windows.h> 
#include <tlhelp32.h> 
#include <tchar.h> 
#include <stdio.h> 
// Forward declarations: 
BOOL GetProcessList( ); 
BOOL ListProcessModules( DWORD dwPID ); 
BOOL ListProcessThreads( DWORD dwOwnerPID ); 
void printError( TCHAR* msg ); 
void main( ) 
{  
    GetProcessList( ); 
} 
BOOL GetProcessList( ) 
{  
    HANDLE hProcessSnap;  
    HANDLE hProcess;  
    PROCESSENTRY32 pe32; //用来存放快照进程信息的一个结构体 
    DWORD dwPriorityClass; // Take a snapshot of all processes in the system.  
    hProcessSnap = CreateToolhelp32Snapshot( TH32CS_SNAPPROCESS,0 );  
    /*
    CreateToolhelp32Snapshot函数为指定的进程、进程使用的堆[HEAP]、模块[MODULE]、线程[THREAD])建立一个快照[snapshot]。   
    HANDLE WINAPI CreateToolhelp32Snapshot(   DWORD dwFlags,//用来指定“快照”中需要返回的对象,可以是TH32CS_SNAPPROCESS等   
                                  DWORD th32ProcessID //一个进程ID号,用来指定要获取哪一个进程的快照,当获取系统进程列表或获取当前进程快照时可以设为0   ); 
    */ 
    if( hProcessSnap == INVALID_HANDLE_VALUE )  
    {  
        printError( TEXT("CreateToolhelp32Snapshot (of processes)") );  
        return( FALSE );  
    } // Set the size of the structure before using it.  
    pe32.dwSize = sizeof( PROCESSENTRY32 ); // Retrieve information about the first process,// and exit if unsuccessful 
    if( !Process32First( hProcessSnap,&pe32 ) )  
    {  
        printError( TEXT("Process32First") ); // show cause of failure  
        CloseHandle( hProcessSnap ); // clean the snapshot object  
        ( FALSE );  
    } // Now walk the snapshot of processes,and  
    // display information about each process in turn  
    do { 
        printf( "nn=====================================================" );  
        _tprintf( TEXT("nPROCESS NAME: %s"),pe32.szExeFile );  
        printf( "n-----------------------------------------------------" ); // Retrieve the priority class.  
        dwPriorityClass = 0;  
        hProcess = OpenProcess( PROCESS_ALL_ACCESS,FALSE,pe32.th32ProcessID );  
        /*
        OpenProcess 函数用来打开一个已存在的进程对象,并返回进程的句柄。  
        1.函数原型   HANDLE OpenProcess(   DWORD dwDesiredAccess,//渴望得到的访问权限(标志)   
                                         BOOL bInheritHandle,// 是否继承句柄   
                                         DWORD dwProcessId// 进程标示符   ); 
        */ 
        if( hProcess == NULL ) 
            printError( TEXT("OpenProcess") );  
        else {  
            dwPriorityClass = GetPriorityClass( hProcess );  
            if( !dwPriorityClass )  
                printError( TEXT("GetPriorityClass") );  
            CloseHandle( hProcess );  
        }  
        printf( "n Process ID = 0x%08X",pe32.th32ProcessID );  
        printf( "n Thread count = %d",pe32.cntThreads );  
        printf( "n Parent process ID = 0x%08X",pe32.th32ParentProcessID );  
        printf( "n Priority base = %d",pe32.pcPriClassBase );  
        if( dwPriorityClass )  
            printf( "n Priority class = %d",dwPriorityClass ); // List the modules and threads associated with this process  
        //ListProcessModules( pe32.th32ProcessID );  
        //ListProcessThreads( pe32.th32ProcessID ); 
    } while( Process32Next( hProcessSnap,&pe32 ) ); 
    CloseHandle( hProcessSnap );  
    return( TRUE ); 
} 
BOOL ListProcessModules( DWORD dwPID ) 
{ 
    HANDLE hModuleSnap = INVALID_HANDLE_VALUE;  
    MODULEENTRY32 me32; // Take a snapshot of all modules in the specified process.  
    hModuleSnap = CreateToolhelp32Snapshot( TH32CS_SNAPMODULE,dwPID ); 
    if( hModuleSnap == INVALID_HANDLE_VALUE )  
    { 
        printError( TEXT("CreateToolhelp32Snapshot (of modules)") );  
        return( FALSE ); 
    } // Set the size of the structure before using it. 
    me32.dwSize = sizeof( MODULEENTRY32 ); // Retrieve information about the first module,// and exit if unsuccessful  
    if( !Module32First( hModuleSnap,&me32 ) )  
    { 
        printError( TEXT("Module32First") ); // show cause of failure  
        CloseHandle( hModuleSnap ); // clean the snapshot object  
        return( FALSE ); 
    } // Now walk the module list of the process,// and display information about each module  
    do { 
        _tprintf( TEXT("nn MODULE NAME: %s"),me32.szModule ); 
        _tprintf( TEXT("n Executable = %s"),me32.szExePath ); 
        printf( "n Process ID = 0x%08X",me32.th32ProcessID ); 
        printf( "n Ref count (g) = 0x%04X",me32.GlblcntUsage ); 
        printf( "n Ref count (p) = 0x%04X",me32.ProccntUsage ); 
        printf( "n Base address = 0x%08X",(DWORD) me32.modBaseAddr );  
        printf( "n Base size = %d",me32.modBaseSize ); 
    } while( Module32Next( hModuleSnap,&me32 ) );  
    CloseHandle( hModuleSnap );  
    return( TRUE ); 
} 
BOOL ListProcessThreads( DWORD dwOwnerPID )  
{  
    HANDLE hThreadSnap = INVALID_HANDLE_VALUE;  
    THREADENTRY32 te32; // Take a snapshot of all running threads  
    hThreadSnap = CreateToolhelp32Snapshot( TH32CS_SNAPTHREAD,0 );  
    if( hThreadSnap == INVALID_HANDLE_VALUE )  
        return( FALSE ); // Fill in the size of the structure before using it.  
    te32.dwSize = sizeof(THREADENTRY32 ); // Retrieve information about the first thread,// and exit if unsuccessful  
    if( !Thread32First( hThreadSnap,&te32 ) )  
    { 
        printError( TEXT("Thread32First") ); // show cause of failure  
        CloseHandle( hThreadSnap ); // clean the snapshot object  
        return( FALSE ); 
    } // Now walk the thread list of the system,// and display information about each thread  
    // associated with the specified process  
    do {  
        if( te32.th32OwnerProcessID == dwOwnerPID )  
        {  
            printf( "nn THREAD ID = 0x%08X",te32.th32ThreadID );  
            printf( "n Base priority = %d",te32.tpBasePri ); 
            printf( "n Delta priority = %d",te32.tpDeltaPri );  
        }  
    } while( Thread32Next(hThreadSnap,&te32 ) );  
    CloseHandle( hThreadSnap );  
    return( TRUE ); 
} 
void printError( TCHAR* msg ) 
{  
    DWORD eNum;  
    TCHAR sysMsg[256];  
    TCHAR* p;  
    eNum = GetLastError( );  
    FormatMessage( FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,NULL,eNum,MAKELANGID(LANG_NEUTRAL,SUBLANG_DEFAULT),// Default language  
        sysMsg,256,NULL ); // Trim the end of the line and terminate it with a null  
    p = sysMsg; 
    while( ( *p > 31 ) || ( *p == 9 ) )  
        ++p;  
    do { 
        *p-- = 0; 
    } while( ( p >= sysMsg ) && ( ( *p == '.' ) || ( *p < 33 ) ) ); // Display the message  
    _tprintf( TEXT("n WARNING: %s failed with error %d (%s)"),msg,sysMsg ); 
}   

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读