GetProcessHandleCount() -- 获取属于指定进程的已打开句柄数


想获取指定进程打开的句柄数:

用GetProcessHandleCount()。

枚举进程信息:

NtQuerySystemInformation( ).

GetProcessHandleCount() -- 获取属于指定进程的已打开句柄数

GetProcessHandleCount()  原型如下:
BOOL WINAPI GetProcessHandleCount(
  __in     HANDLE hProcess,
  __inout  PDWORD pdwHandleCount
);

该函数用来获取属于指定进程的已打开的句柄数。

第 1 个参数  hProcess  是输入参数,指定进程的句柄。

第 2 个参数  pdwHandleCount  用来存储返回的属于指定进程的已打开的句柄数。

通常,任何一个进程都可以创建一个已经存在的内核对象的句柄,创建成功后,该进程里所拥有的打开句柄数就会增加(可能增加 1 或者大于 1),比如调用 CreateFile() 函数创建一个文件。

测试代码
#include "stdafx.h"
#include <Windows.h>

int _tmain(int argc, _TCHAR* argv[])
{

    DWORD dwHandleCount;
    GetProcessHandleCount(GetCurrentProcess(), &dwHandleCount);
    printf ("Current Process Handle count : %d\n", dwHandleCount);

    HANDLE fh;
    fh = CreateFile (TEXT("Groad.txt"), GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_ALWAYS, 0, NULL);  //创建一个文件
       if (fh == INVALID_HANDLE_VALUE) {
        _tprintf (_T("Cannot open file\n"));
        exit (1);
    }
    

    GetProcessHandleCount(GetCurrentProcess(), &dwHandleCount);
    printf ("Now, Current Process Handle count : %d\n",dwHandleCount);

    
    return 0;
}

运行输出:
Current Process Handle count : 11
Now, Current Process Handle count : 12
可以使用Windows的性能计器API来获取某个进程打开的文件句柄。 首先,需要使用`PdhOpenQuery`函创建一个查询对象。然后,使用`PdhAddCounter`函将要查询的计器添加到查询对象中。计器的路径格式为`\Process(<进程名或进程ID>)\Handle Count`。最后,使用`PdhCollectQueryData`函收集计据,并使用`PdhGetFormattedCounterValue`函获取器值。 以下是一个示例代码: ```c++ #include <pdh.h> #include <iostream> #include <string> #pragma comment(lib, "pdh.lib") int main() { PDH_STATUS status; HQUERY query; HCOUNTER counter; // 创建查询对象 status = PdhOpenQuery(nullptr, 0, &query); if (status != ERROR_SUCCESS) { std::cerr << "PdhOpenQuery failed with error code " << status << std::endl; return 1; } // 添加计器 std::string processName = "notepad.exe"; // 要查询的进程名 status = PdhAddCounter(query, ("\\Process(" + processName + ")\\Handle Count").c_str(), 0, &counter); if (status != ERROR_SUCCESS) { std::cerr << "PdhAddCounter failed with error code " << status << std::endl; return 1; } // 收集计据 status = PdhCollectQueryData(query); if (status != ERROR_SUCCESS) { std::cerr << "PdhCollectQueryData failed with error code " << status << std::endl; return 1; } // 获取器值 PDH_FMT_COUNTERVALUE value; status = PdhGetFormattedCounterValue(counter, PDH_FMT_LONG, nullptr, &value); if (status != ERROR_SUCCESS) { std::cerr << "PdhGetFormattedCounterValue failed with error code " << status << std::endl; return 1; } std::cout << "Handle Count: " << value.longValue << std::endl; // 关闭查询对象 PdhCloseQuery(query); return 0; } ``` 其中,`PDH_STATUS`和`HCOUNTER`等类型需要包含`pdh.h`头文件。`PdhAddCounter`函的第一个参为查询对象,第二个参为计器路径,第三个参为保留值,第四个参为计句柄。`PdhGetFormattedCounterValue`函的第一个参为计句柄,第二个参为计器值的格式,第三个参为字符串格式化模板(可选),第四个参为计器值结构体。在使用完性能计器后,需要使用`PdhCloseQuery`函关闭查询对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值