本文實(shí)例講述了VC下通過(guò)系統(tǒng)快照實(shí)現(xiàn)進(jìn)程管理的方法,分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
一、引言
每一個(gè)應(yīng)用程序?qū)嵗谶\(yùn)行起來(lái)后都會(huì)在當(dāng)前系統(tǒng)下產(chǎn)生一個(gè)進(jìn)程,大多數(shù)應(yīng)用程序均擁有可視界面,用戶可以通過(guò)標(biāo)題欄上的關(guān)閉按鈕關(guān)閉程序。但是也有為數(shù)不少的在后臺(tái)運(yùn)行的程序是沒(méi)有可視界面的,對(duì)于這類(lèi)應(yīng)用程序用戶只能通過(guò)CTRL+ALT+DEL熱鍵呼出"關(guān)閉程序"對(duì)話框顯示出當(dāng)前系統(tǒng)進(jìn)程列表,從中可以結(jié)束指定的任務(wù)。顯然,該功能在一些系統(tǒng)監(jiān)控類(lèi)軟件中還是非常必需的,其處理過(guò)程大致可以分為兩步:借助系統(tǒng)快照實(shí)現(xiàn)對(duì)系統(tǒng)當(dāng)前進(jìn)程的枚舉和根據(jù)枚舉結(jié)果對(duì)進(jìn)程進(jìn)行管理。本文下面即將對(duì)此過(guò)程的實(shí)現(xiàn)進(jìn)行介紹。
二、當(dāng)前進(jìn)程的枚舉
要對(duì)當(dāng)前系統(tǒng)所有已開(kāi)啟的進(jìn)程進(jìn)行枚舉,就必須首先獲得那些加載到內(nèi)存的進(jìn)程當(dāng)前相關(guān)狀態(tài)信息。在Windows操作系統(tǒng)下,這些進(jìn)程的當(dāng)前狀態(tài)信息不能直接從進(jìn)程本身獲取,系統(tǒng)已為所有保存在系統(tǒng)內(nèi)存中的進(jìn)程、線程以及模塊等的當(dāng)前狀態(tài)的信息制作了一個(gè)只讀副本--系統(tǒng)快照,用戶可以通過(guò)對(duì)系統(tǒng)快照的訪問(wèn)完成對(duì)進(jìn)程當(dāng)前狀態(tài)的檢測(cè)。在具體實(shí)現(xiàn)時(shí),系統(tǒng)快照句柄的獲取是通過(guò)Win32 API函數(shù)CreateToolhelp32Snapshot()來(lái)完成的,通過(guò)該函數(shù)不僅可以獲取進(jìn)程快照,而且對(duì)于堆、模塊和線程的系統(tǒng)快照同樣可以獲取。該函數(shù)原型聲明如下:
其中,參數(shù)dwFlags:指定將要?jiǎng)?chuàng)建包含哪一類(lèi)系統(tǒng)信息的快照句柄,本程序中只需要檢索系統(tǒng)進(jìn)程信息,因此可將其設(shè)置為 TH32CS_SNAPPROCESS;函數(shù)第二個(gè)參數(shù)th32ProcessID`則指定了進(jìn)程的標(biāo)識(shí)號(hào),當(dāng)設(shè)置為0時(shí)指定當(dāng)前進(jìn)程。如果成功函數(shù)將返回一個(gè)包含進(jìn)程信息的系統(tǒng)快照句柄。在得到快照句柄之后只能以只讀的方式對(duì)其進(jìn)行訪問(wèn)。至于對(duì)系統(tǒng)快照句柄的使用同普通對(duì)象句柄的使用并沒(méi)有什么太大區(qū)別,在使用完之后也需要通過(guò)CloseHandle()函數(shù)將其銷(xiāo)毀。
在得到系統(tǒng)的快照句柄后,就可以對(duì)當(dāng)前進(jìn)程的標(biāo)識(shí)號(hào)進(jìn)行枚舉了,通過(guò)這些枚舉出的進(jìn)程標(biāo)識(shí)號(hào)可以很方便的對(duì)進(jìn)程進(jìn)行管理。進(jìn)程標(biāo)識(shí)號(hào)通過(guò)函數(shù) Process32First() 和 Process32Next()而得到,這兩個(gè)函數(shù)可以枚舉出系統(tǒng)當(dāng)前所有開(kāi)啟的進(jìn)程,并且可以得到相關(guān)的進(jìn)程信息。 這兩個(gè)函數(shù)原型聲明如下:
以上兩個(gè)函數(shù)分別用于獲得系統(tǒng)快照中第一個(gè)和下一個(gè)進(jìn)程的信息,并將獲取得到的信息保存在指針lppe所指向的PROCESSENTRY32結(jié)構(gòu)中。函數(shù)第一個(gè)參數(shù)hSnapshot為由CreateToolhelp32Snapshot()函數(shù)返回得到的系統(tǒng)快照句柄;第二個(gè)參數(shù)lppe為指向結(jié)構(gòu) PROCESSENTRY32的指針,PROCESSENTRY32結(jié)構(gòu)可對(duì)進(jìn)程作一個(gè)較為全面的描述,其定義如下:
以上三個(gè)API函數(shù)均在頭文件tlhelp32.h中聲明,運(yùn)行時(shí)需要有kernel32.lib庫(kù)的支持。通過(guò)這三個(gè)函數(shù)可以枚舉出當(dāng)前系統(tǒng)已開(kāi)啟的所有進(jìn)程,并可獲取到進(jìn)程的各相關(guān)信息,下面給出一個(gè)簡(jiǎn)單的應(yīng)用示例。在此示例中將枚舉出系統(tǒng)的所有進(jìn)程,并獲取各進(jìn)程的標(biāo)識(shí)號(hào)和相應(yīng)程序的絕對(duì)路徑,進(jìn)程標(biāo)識(shí)號(hào)在下一步對(duì)進(jìn)程的管理中將要用到,程序路徑則直接通過(guò)列表控件顯示出來(lái):
三、對(duì)進(jìn)程的管理
在得到各枚舉進(jìn)程的標(biāo)識(shí)號(hào)后就可以實(shí)現(xiàn)對(duì)進(jìn)程的管理了,由于被管理進(jìn)程在當(dāng)前進(jìn)程之外,因此必須首先通過(guò)OpenProcess()函數(shù)來(lái)獲取一個(gè)已經(jīng)存在的進(jìn)程對(duì)象的句柄,然后才可以通過(guò)該句柄對(duì)指定的進(jìn)程進(jìn)行管理和控制。在OpenProcess()函數(shù)的調(diào)用時(shí)把進(jìn)程標(biāo)識(shí)號(hào)作為參數(shù)傳入, OpenProcess()函數(shù)的原型聲明如下:
如果函數(shù)執(zhí)行成功將返回由進(jìn)程標(biāo)識(shí)號(hào)指定的進(jìn)程對(duì)象句柄。下面同樣也對(duì)其給出一個(gè)簡(jiǎn)單的應(yīng)用示例,在此示例中根據(jù)所獲取的進(jìn)程對(duì)象句柄通過(guò)TerminateProcess()函數(shù)將指定的進(jìn)程終止:
由于需要在調(diào)用TerminateProcess()函數(shù)終止進(jìn)程時(shí)確保進(jìn)程句柄可有效使用,因此在前面調(diào)用OpenProcess()時(shí),需要指定其訪問(wèn)標(biāo)致為PROCESS_TERMINATE。
四、小結(jié)
本文主要對(duì)系統(tǒng)快照以及通過(guò)借助系統(tǒng)快照而對(duì)系統(tǒng)當(dāng)前進(jìn)程進(jìn)行枚舉、管理的實(shí)現(xiàn)方法做了簡(jiǎn)要介紹。在本文只討論了包含有進(jìn)程信息的系統(tǒng)快照,感興趣的讀者完全可以用類(lèi)似的方法實(shí)現(xiàn)對(duì)包含有線程、堆或是摸塊等信息的系統(tǒng)快照的應(yīng)用。本文所述程序在Windows 98下由Microsoft Visual C++ 6.0編譯通過(guò)。
希望本文所述對(duì)大家的VC程序設(shè)計(jì)有所幫助。
|
新聞熱點(diǎn)
疑難解答
圖片精選