通过Handle处理进程

 

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获得该进程主窗口的句柄(来自优快云)

    一个进程可以拥有很多主窗口,也可以不拥有主窗口,所以这样的函数是不存在的,所幸的是,相反的函数是有的。所以我们可以调用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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lbjayo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值