createtoolhelp32snapshot是否能获取64位进程快照

 我来答
zone殿
推荐于2016-11-26 · TA获得超过3387个赞
知道大有可为答主
回答量:1579
采纳率:65%
帮助的人:699万
展开全部
1.操作进程快照
1)Process32First函数
[cpp] view plaincopy
BOOL WINAPI Process32First(
HANDLE hSnapshot,
LPPROCESSENTRY32 lppe );
功能:获取进程快照列表的第一个进程状态信息。
参数:hSnapshot为快照句柄;lppe参数为指向PROCESSENTRY32结构体的指针,该结构体的形式如下:
[cpp] view plaincopy
typedef struct tagPROCESSENTRY32 {
DWORD dwSize;//该结构体的大小
DWORD cntUsage;//进程的引用计数
DWORD th32ProcessID; //进程的ID
DWORD th32DefaultHeapID; //进程的默认堆ID
DWORD th32ModuleID; //进程模块ID
DWORD cntThreads; //次进程开启的线程计数
DWORD th32ParentProcessID; //此进程的父进程ID
LONG pcPriClassBase; //线程的相对优先级
DWORD dwFlags; //保留字段
TCHAR szExeFile[MAX_PATH];//进程的全名
} PROCESSENTRY32;
typedef PROCESSENTRY32 * PPROCESSENTRY32;
注意:调用该函数必须制定dwSize的大小。
2)Process32Next函数
[cpp] view plaincopy
BOOL WINAPI Process32Next(
HANDLE hSnapshot,
LPPROCESSENTRY32 lppe );
功能:该函数获取进程快照列表中的下一个进程状态信息,该函数返回TRUE,表示成功获取;返回FLASE,表示失败。
2.操作线程快照
1)Thread3First含糊
[cpp] view plaincopy
BOOL WINAPI Thread32First(
HANDLE hSnapshot,
LPTHREADENTRY32 lpte );
功能:获取快照列表中的第一个线程的状态信息。
参数:hSnapshot为系统快照句柄;lpte为一个指向THREADENTRY32结构体的指针,该结构的形式如下:
[cpp] view plaincopy
typedef struct tagTHREADENTRY32{
DWORD dwSize; //结构体的大小
DWORD cntUsage; //线程引用计数
DWORD th32ThreadID; //线程的ID
DWORD th32OwnerProcessID; //拥有该线程的进程ID
LONG tpBasePri; //线程的相对优先级,共7个值
LONG tpDeltaPri; //这个成员已经不再被使用,总是设置为零。
DWORD dwFlags;//保留字段,没使用,为0.
} THREADENTRY32;
typedef THREADENTRY32 * PTHREADENTRY32;
2)Thread32Next函数
[cpp] view plaincopy
BOOL WINAPI Thread32Next(
HANDLE hSnapshot,
LPTHREADENTRY32 lpte );
功能:获取快照列表中的下一个线程快照状态信息。
3.操作堆快照
1)Heap32First函数
[cpp] view plaincopy
BOOL WINAPI Heap32First(
HANDLE hSnapshot,
LPHEAPENTRY32 lphe,
DWORD th32ProcessID,
DWORD th32HeapID );
该函数:获取快照中响应的堆。
参数:
[cpp] view plaincopy
typedef struct tagHEAPENTRY32
{
DWORD dwSize;//结构体大小
HANDLE hHandle; //指向一个堆块
DWORD dwAddress; //堆的拾起地址
DWORD dwBlockSize; //堆的大小
DWORD dwFlags; //保留
DWORD dwLockCount; //没使用
DWORD dwResvd; //不再使用
DWORD th32ProcessID; //拥有该对的进程ID
DWORD th32HeapID; //该堆的标识符
} HEAPENTRY32;
typedef HEAPENTRY32 * PHEAPENTRY32;
typedef HEAPENTRY32 * LPHEAPENTRY32;
2)Heap32Next函数
[cpp] view plaincopy
BOOL WINAPI Heap32Next(
HANDLE hSnapshot,
LPHEAPENTRY32 lphe );
3)Heap32LitFirst函数
[cpp] view plaincopy
BOOL WINAPI Heap32ListFirst(
HANDLE hSnapshot,
LPHEAPLIST32 lphl );
参数:
[cpp] view plaincopy
typedef struct tagHEAPLIST32 {
DWORD dwSize;//结构体大小
DWORD th32ProcessID; //进程ID
DWORD th32HeapID; //堆栈标识符
DWORD dwFlags; //保留,为0
} HEAPLIST32;
typedef HEAPLIST32 * PHEAPLIST32;
typedef HEAPLIST32 * LPHEAPLIST32;
4)Heap32ListNext函数
[cpp] view plaincopy
BOOL WINAPI Heap32ListNext(
HANDLE hSnapshot,
LPHEAPLIST32 lphl );

4.操作模块快照
1)Module32First函数
[cpp] view plaincopy
BOOL WINAPI Module32First(
HANDLE hSnapshot,
LPMODULEENTRY32 lpme );
功能:从系统快照中获取第一个模块信息。
参数:lpme为指向MODULEENTRY32结构体的指针,其形式如下:
[cpp] view plaincopy
typedef struct tagMODULEENTRY32 {
DWORD dwSize; //该结构体的大小
DWORD th32ModuleID; //进程上下文模块标识符
DWORD th32ProcessID; //进程标识符
DWORD GlblcntUsage; //全局模块引用计数
DWORD ProccntUsage; //所属进程的模块引用计数
BYTE *modBaseAddr; //所属进程的基地址
DWORD modBaseSize; //
HMODULE hModule;//模块的句柄
TCHAR szModule[MAX_MODULE_NAME32 + 1]; //模块名
TCHAR szExePath[MAX_PATH]; //路径
} MODULEENTRY32;
typedef MODULEENTRY32 * PMODULEENTRY32;
2)Module32Next函数
[cpp] view plaincopy
BOOL WINAPI Module32Next(
HANDLE hSnapshot,
LPMODULEENTRY32 lpme );
5.Toolhelp32ReadProcessMemory 函数获得指定进程中指定内存区域的数据。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式