首页  >  文章  >  后端开发  >  如何在 C 中按名称获取进程句柄?

如何在 C 中按名称获取进程句柄?

Barbara Streisand
Barbara Streisand原创
2024-11-23 00:38:11459浏览

How to Get a Process Handle by Name in C  ?

在 C 中按名称访问进程句柄

在 C 中,按名称检索进程句柄是管理系统资源的一项常见任务。以下是实现此目的的方法:

#include <windows.h>
#include <tlhelp32.h>

int main(int argc, char *argv[])
{
    PROCESSENTRY32 entry;
    entry.dwSize = sizeof(PROCESSENTRY32);

    HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);

    if (Process32First(snapshot, &entry) == TRUE)
    {
        while (Process32Next(snapshot, &entry) == TRUE)
        {
            if (_strcmpi(entry.szExeFile, "target.exe") == 0)
            {
                HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, entry.th32ProcessID);

                // Perform desired operations here...

                CloseHandle(hProcess);
            }
        }
    }

    CloseHandle(snapshot);

    return 0;
}

注意:

  • CreateToolhelp32Snapshot 创建当前系统进程的快照。
  • Process32First和 Process32Next 迭代该过程list。
  • _strcmpi 比较字符串时不区分大小写。
  • OpenProcess 使用指定的访问权限打开进程句柄。

如果您没有足够的权限(具体来说,“调试权限”),您可能需要使用 EnableDebugPriv 调整令牌权限功能:

void EnableDebugPriv()
{
    HANDLE hToken;
    LUID luid;
    TOKEN_PRIVILEGES tkp;

    ...

    // Adjust token privileges to enable debugging
}

以上是如何在 C 中按名称获取进程句柄?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn