1.知道进程handle 获取进程名称。
PROCESS_INFORMATION* processInfo =(PROCESS_INFORMATION*)pid();
HANDLE hProcess =processInfo->hProcess;
char buffer[255];
ZeroMemory(buffer,255*sizeof(char));
GetModuleFileNameExA(hProcess,0,buffer,255*sizeof(char));
2.知道进程handle,获取内存使用率
PROCESS_INFORMATION* processInfo = (PROCESS_INFORMATION*)pid();
HANDLE hProcess = processInfo->hProcess;
PROCESS_MEMORY_COUNTERS mem;
mem.cb = sizeof(PROCESS_MEMORY_COUNTERS);
if (GetProcessMemoryInfo(hProcess,&mem,sizeof(mem)))
{
SIZE_T workingMem = mem.WorkingSetSize ;
return workingMem;
}
3.知道进程id获取,进程主窗口,如果有的话
通过进程ID获得该进程主窗口的句柄(来自CSDN)
一个进程可以拥有很多主窗口,也可以不拥有主窗口,所以这样的函数是不存在的,所幸的是,相反的函数是有的。所以我们可以调用EnumWindows来判断所有的窗口是否属于这个进程。
一般网络上是没有这一段的
但是一个进程他可以拥有很多窗口,要判断哪个是主窗口,除了判断进程Id之外,还要判断是否可见,因为我们平常看到的窗口一般是可见的,但有些程序它会创建好几个窗口,主窗口只是其中的一个,其他窗口只是没有Show出来或者只是没有大小的窗口,但一样是顶层窗口,像我试验了记事本,就有3个顶层窗口,注意不是子窗口。
typedef struct tagWNDINFO
{
DWORD dwProcessId;
HWND hWnd;
} WNDINFO, *LPWNDINFO;
BOOL CALLBACK YourEnumProc(HWND hWnd,LPARAM lParam)
{
DWORD dwProcessId;
GetWindowThreadProcessId(hWnd, &dwProcessId);
LPWNDINFO pInfo = (LPWNDINFO)lParam;
if(dwProcessId == pInfo->dwProcessId)
{
bool isWindowVisible = IsWindowVisible(hWnd);
if(isWindowVisible == true)
{
pInfo->hWnd = hWnd;
return FALSE;
}
}
return TRUE;
}
HWND GetProcessMainWnd(DWORD dwProcessId)
{
WNDINFO wi;
wi.dwProcessId = dwProcessId;
wi.hWnd = NULL;
EnumWindows(YourEnumProc,(LPARAM)&wi);
return wi.hWnd;
}
如果这个进程没有窗口,函数返回NULL