VC下經由過程體系快照完成過程治理的辦法。本站提示廣大學習愛好者:(VC下經由過程體系快照完成過程治理的辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是VC下經由過程體系快照完成過程治理的辦法正文
本文實例講述了VC下經由過程體系快照完成過程治理的辦法,分享給年夜家供年夜家參考。詳細完成辦法以下:
1、引言
每個運用法式實例在運轉起來後都邑在以後體系下發生一個過程,年夜多半運用法式均具有可視界面,用戶可以經由過程題目欄上的封閉按鈕封閉法式。然則也無為數很多的在後台運轉的法式是沒有可視界面的,關於這類運用法式用戶只能經由過程CTRL+ALT+DEL熱鍵呼出"封閉法式"對話框顯示出以後體系過程列表,從中可以停止指定的義務。明顯,該功效在一些體系監控類軟件中照樣異常必須的,其處置進程年夜致可以分為兩步:借助體系快照完成對體系以後過程的列舉和依據列舉成果對過程停止治理。本文上面行將對此進程的完成停止引見。
2、以後過程的列舉
要對以後體系一切已開啟的過程停止列舉,就必需起首取得那些加載到內存的過程以後相干狀況信息。在Windows操作體系下,這些過程確當前狀況信息不克不及直接從過程自己獲得,體系已為一切保留在體系內存中的過程、線程和模塊等確當前狀況的信息制造了一個只讀正本--體系快照,用戶可以經由過程對體系快照的拜訪完成對過程以後狀況的檢測。在詳細完成時,體系快照句柄的獲得是經由過程Win32 API函數CreateToolhelp32Snapshot()來完成的,經由過程該函數不只可以獲得過程快照,並且關於堆、模塊和線程的體系快照異樣可以獲得。該函數原型聲明以下:
HANDLE WINAPI CreateToolhelp32Snapshot(DWORD dwFlags,DWORD th32ProcessID);
個中,參數dwFlags:指定將要創立包括哪一類體系信息的快照句柄,本法式中只須要檢索體系過程信息,是以可將其設置為 TH32CS_SNAPPROCESS;函數第二個參數th32ProcessID`則指定了過程的標識號,當設置為0時指定以後過程。假如勝利函數將前往一個包括過程信息的體系快照句柄。在獲得快照句柄以後只能以只讀的方法對其停止拜訪。至於對體系快照句柄的應用同通俗對象句柄的應用並沒有甚麼太年夜差別,在應用完以後也須要經由過程CloseHandle()函數將其燒毀。
在獲得體系的快照句柄後,便可以對以後過程的標識號停止列舉了,經由過程這些列舉出的過程標識號可以很便利的對過程停止治理。過程標識號經由過程函數 Process32First() 和 Process32Next()而獲得,這兩個函數可以列舉出體系以後一切開啟的過程,而且可以獲得相干的過程信息。 這兩個函數原型聲明以下:
BOOL WINAPI Process32First(HANDLE hSnapshot, LPPROCESSENTRY32 lppe);
BOOL WINAPI Process32Next(HANDLE hSnapshot,LPPROCESSENTRY32 lppe);
以上兩個函數分離用於取得體系快照中第一個和下一個過程的信息,並將獲得獲得的信息保留在指針lppe所指向的PROCESSENTRY32構造中。函數第一個參數hSnapshot為由CreateToolhelp32Snapshot()函數前往獲得的體系快照句柄;第二個參數lppe為指向構造 PROCESSENTRY32的指針,PROCESSENTRY32構造可對過程作一個較為周全的描寫,其界說以下:
typedef struct tagPROCESSENTRY32 {
DWORD dwSize; // 構造年夜小;
DWORD cntUsage; // 此過程的援用計數;
DWORD th32ProcessID; // 過程ID;
DWORD th32DefaultHeapID; // 過程默許堆ID;
DWORD th32ModuleID; // 過程模塊ID;
DWORD cntThreads; // 此過程開啟的線程計數;
DWORD th32ParentProcessID; // 父過程ID;
LONG pcPriClassBase; // 線程優先權;
DWORD dwFlags; // 保存;
char szExeFile[MAX_PATH]; // 過程全名;
} PROCESSENTRY32;
以上三個API函數均在頭文件tlhelp32.h中聲明,運轉時須要有kernel32.lib庫的支撐。經由過程這三個函數可以列舉出以後體系已開啟的一切過程,並可獲得到過程的各相干信息,上面給出一個簡略的運用示例。在此示例中將列舉出體系的一切過程,並獲得各過程的標識號和響應法式的相對途徑,過程標識號鄙人一步對過程的治理中將要用到,法式途徑則直接經由過程列表控件顯示出來:
// PROCESSENTRY32構造對象
PROCESSENTRY32 pe;
// 創立快照句柄
HANDLE hSnapshot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);
// 先搜刮體系中第一個過程的信息
Process32First(hSnapshot, &pe);
// 上面對體系中的一切過程停止列舉,並保留其信息
do{
// 把過程對應的文件途徑名填出列表框
int index = m_ctlwndList.AddString(pe.szExeFile);
// 設置列表框中該項的Data響應的過程的ID號,利於今後終止該過程
m_ctlwndList.SetItemData(index, pe.th32ProcessID);
} while (Process32Next(hSnapshot, &pe));
// 封閉快照句柄
CloseHandle(hSnapshot);
3、對過程的治理
在獲得各列舉過程的標識號後便可以完成對過程的治理了,因為被治理過程在以後過程以外,是以必需起首經由過程OpenProcess()函數來獲得一個曾經存在的過程對象的句柄,然後才可以經由過程該句柄對指定的過程停止治理和掌握。在OpenProcess()函數的挪用時把過程標識號作為參數傳入, OpenProcess()函數的原型聲明以下:
HANDLE OpenProcess(DWORD dwDesiredAccess, // 拜訪標記
BOOL bInheritHandle, // 處置繼續的標記
DWORD dwProcessId // 過程標識號);
假如函數履行勝利將前往由過程標識號指定的過程對象句柄。上面異樣也對其給出一個簡略的運用示例,在此示例中依據所獲得的過程對象句柄經由過程TerminateProcess()函數將指定的過程終止:
// 取得此時列表框中的所選項的數據,即該項對應的過程的ID值
int index = m_ctlwndList.GetCurSel();
// 取得此時列表框中的選項,即該項對應的過程的ID值
DWORD data = m_ctlwndList.GetItemData(index);
// 應用過程的ID值,翻開該過程,取得過程句柄
HANDLE hProcess = OpenProcess(PROCESS_TERMINATE, FALSE,data);
// 檢測句柄的有用性,若有效則終止該過程
if (hProcess)
TerminateProcess(hProcess,0);
因為須要在挪用TerminateProcess()函數終止過程時確保過程句柄可有用應用,是以在後面挪用OpenProcess()時,須要指定其拜訪美麗為PROCESS_TERMINATE。
4、小結
本文重要對體系快照和經由過程借助體系快照而對體系以後過程停止列舉、治理的完成辦法做了扼要引見。在本文只評論辯論了包括有過程信息的體系快照,感興致的讀者完整可以用相似的辦法完成對包括有線程、堆或是摸塊等信息的體系快照的運用。本文所述法式在Windows 98下由Microsoft Visual C++ 6.0編譯經由過程。
願望本文所述對年夜家的VC法式設計有所贊助。