C での名前によるプロセス ハンドルの取得
C では、名前に基づいてプロセスを操作する必要がある状況に遭遇することがあります。たとえば、ウィンドウ ハンドルに依存せずに「example.exe」というプロセスを終了したい場合があります。この質問では、この特定のシナリオを詳しく掘り下げ、解決策を示します。
プロセス ハンドルを名前で取得するには、Windows API 関数 CreateToolhelp32Snapshot および Process32Next を利用できます。このアプローチを示すコード スニペットは次のとおりです。
#include <cstdio> #include <windows.h> #include <tlhelp32.h> int main() { // Create a snapshot of running processes HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); // Iterate over the processes PROCESSENTRY32 entry; entry.dwSize = sizeof(PROCESSENTRY32); if (Process32First(snapshot, &entry) == TRUE) { while (Process32Next(snapshot, &entry) == TRUE) { // Check if this is the process we want if (strcmp(entry.szExeFile, "example.exe") == 0) { // Open a handle to the process HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, entry.th32ProcessID); // Perform desired operations on the process CloseHandle(hProcess); // Close the handle } } } CloseHandle(snapshot); // Close the snapshot handle return 0; }
このソリューションは、実行中のすべてのプロセスを反復処理し、それらの実行可能ファイル名を「example.exe」と比較します。一致が見つかると、そのプロセスへのハンドルが取得され、(TerminateProcess 経由で) 終了などの操作を実行するために使用できます。
注: OpenProcess で PROCESS_ALL_ACCESS を使用する予定の場合場合によっては、SE_DEBUG_NAME 権限を有効にしてプロセスの権限を昇格する必要があります。これを行うコードを以下に示します。
void EnableDebugPriv() { // Enable debug privilege HANDLE hToken; LUID luid; TOKEN_PRIVILEGES tkp; OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken); LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &luid); tkp.PrivilegeCount = 1; tkp.Privileges[0].Luid = luid; tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED; AdjustTokenPrivileges(hToken, false, &tkp, sizeof(tkp), NULL, NULL); CloseHandle(hToken); }
以上がC でプロセス ハンドルを名前で取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。