枚举进程,线程,堆 CreateToolhelp32Snapshot

Takes a snapshot of the processes and the heaps, modules, and threads used by the processes.
对当前系统进行一个快照。
函数定义:
HANDLE WINAPI CreateToolhelp32Snapshot
                                                                          DWORD dwFlags,      
                                                                          DWORD th32ProcessID 
                                                                         );
参数说明:
dwFlags:要枚举的类型,一般取值如下:
                                                             TH32CS_SNAPPROCESS 枚举进程
                                                             TH32CS_SNAPMODULE  枚举进程中的dll
                                                             TH32SNAPTHREAD  枚举进程中的线程
th32ProcessID:当枚举进程时此参数被忽略,可以为0,其他情况表示进程的ID发你会

返回值:
成功返回一个有效的句柄,失败返回INVALID_HANDLE_VALUE,CloseHandle关掉打开的句柄

举例说明:
下面写一个程序:对当前系统进行快照,然后输出进程ID ,进程名,进程的父进程ID。
进行快照后要用到 Process32First  Process32Next 函数交替枚举信息

    int main()
{
HANDLE hTLSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
if (INVALID_HANDLE_VALUE == hTLSnapshot)
{
return 0;
}

PROCESSENTRY32 pe = {0};
pe.dwSize = sizeof(PROCESSENTRY32);

BOOL bRet = Process32First(hTLSnapshot, &pe);
//int nErr = GetLastError();
if (!bRet)
{
CloseHandle(hTLSnapshot);
return 0;
}

do
{
WCHAR szExeFile[MAX_PATH] = { 0 };
wcscpy_s(szExeFile, MAX_PATH, pe.szExeFile);
DWORD dwParentId = pe.th32ParentProcessID;
DWORD dwProcessId = pe.th32ProcessID;

WCHAR szShow[0x270] = { 0 };
wsprintf(szShow, L"%s\t%d\t%d \r\n", szExeFile, dwParentId, dwProcessId);
wprintf(L"%s \n", szShow);

} while (Process32Next(hTLSnapshot, &pe));

CloseHandle(hTLSnapshot);
return 0;
}

转载于:https://www.cnblogs.com/priarieNew/p/9753409.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值