Untuk mendapatkan semula pemegang proses dengan namanya, kami boleh memanfaatkan fungsi CreateToolhelp32Snapshot untuk mendapatkan gambaran proses sistem. Fungsi ini menyediakan akses kepada maklumat tentang proses yang sedang berjalan, termasuk nama prosesnya.
Coretan kod berikut menunjukkan cara menggunakan CreateToolhelp32Snapshot dan Process32Next untuk mencari proses dengan namakan dan dapatkan semula pemegangnya:
#include <cstdio> #include <windows.h> #include <tlhelp32.h> int main(int, char *[]) { PROCESSENTRY32 entry; entry.dwSize = sizeof(PROCESSENTRY32); HANDLE snapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0); if (Process32First(snapshot, &entry) == TRUE) { while (Process32Next(snapshot, &entry) == TRUE) { if (stricmp(entry.szExeFile, "target.exe") == 0) { HANDLE hProcess = OpenProcess(PROCESS_ALL_ACCESS, FALSE, entry.th32ProcessID); // Do stuff with the process... CloseHandle(hProcess); } } } CloseHandle(snapshot); return 0; }
Jika anda memerlukan Akses PROCESS_ALL_ACCESS, anda mungkin perlu mendayakan keistimewaan SE_DEBUG_NAME buat sementara waktu. Begini cara anda boleh melakukannya:
#include <cstdio> #include <windows.h> #include <tlhelp32.h> void EnableDebugPriv() { 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); } int main(int, char *[]) { EnableDebugPriv(); // ... (Code from previous example)... return 0; }
Atas ialah kandungan terperinci Bagaimana untuk Mengambil Pengendali Proses dengan Namanya dalam C?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!