進程只是提供了一段地址空間和內核對象,,其運行時通過在其地址空間內的主線程來體現的,。當主線程的進入點函數返回時,進程也就隨之結束,。這種進程的終止方式是進程的正常退出,,進程中的所有線程資源都能夠得到正確的清除。除了這種進程的正常退出方式外,,有時還需要在程序中通過代碼來強制結束本進程或其他進程的運行,。ExitProcess()函數的原型為:
void ExitProcess(UINT uExitCode); 其參數uExitCode為進程設置了退出代碼,。該函數具有強制性,在執(zhí)行完畢后進程即被結束,,因此位于其后的任何代碼將不能被執(zhí)行,。雖然ExitProcess()函數可以在結束進程的同時通知與其關聯的動態(tài)鏈接庫,但是由于它的這種執(zhí)行的強制性,,使得ExitProcess()函數在使用上將存在有安全隱患,。例如,如果在程序調用ExitProcess()函數之前曾用new操作符申請過一段空間,,那么將會由于ExitProcess()函數的強制性而無法通過delete操作符將其釋放,,從而造成內存泄露。有鑒于ExitProcess()函數的強制性和不安全性,,在使用時一定要引起注意,。 2.使用TerminateProcess()結束進程 ExitProcess()只能強制執(zhí)行本進程的退出,如果要在一個進程中強制結束其他進程就要用TerminateProcess()來實現,。與ExitProcess()不同,,TerminateProcess()函數執(zhí)行后,被終止的進程是不會的到任何關于程序退出的通知的,。也就是說,,被終止的進程是無法在結束運行前進行退出前的收尾工作的。所以,,通常只有在其他任何方法都無法迫使進程退出時才會考慮使用TerminateProcess()去強制結束進程,。下面給出TerminateProcess()的函數原型: BOOL TerminateProcess(HANDLE hProcess,UINT uExitCode); 參數hProcess和uExitCode分別為進程句柄和退出代碼。如果被結束的是本進程,,可以通過GetCurrentProcess()獲取到句柄,。TerminateProcess()是異步執(zhí)行的,在調用返回后并不能確定被終止進程是否已經真的退出,,如果調用TerminateProcess()的進程對此細節(jié)關心,,可以通過WaitForSingleObject()來等待進程的真正結束。 在VC程序中如何結束系統(tǒng)正在運行的其他進程(該進程必須有窗口界面),,其實很簡單,,按如下步驟進行即可: 1.取得進程的句柄(利用FindWindow函數得到); 2.獲取進程ID號(用GetWindowThreadProcessId函數獲取); 3.打開進程,,OpenProcess函數中的第一個參數設為PROCESS_TERMINATE,,就可以獲取處理該進程的句柄; 4.利用TerminateProcess函數結束進程,將該函數的第二個參數設為4,。 代碼如下: //結束進程 int CStaticFunc::KillProcess(LPCSTR pszClassName, LPCSTR pszWindowTitle) { HANDLE hProcessHandle; ULONG nProcessID; HWND TheWindow; TheWindow = ::FindWindow( NULL, pszWindowTitle ); ::GetWindowThreadProcessId( TheWindow, &nProcessID ); hProcessHandle = ::OpenProcess( PROCESS_TERMINATE, FALSE, nProcessID ); return ::TerminateProcess( hProcessHandle, 4 ); } 而啟動進程則只需要CreateProcess函數就可完成,,需要注意的是這個函數的幾個輸入參數,第一個參數是 //啟動新進程 int CStaticFunc::CreateNewProcess(LPCSTR pszExeName) { PROCESS_INFORMATION piProcInfoGPS; STARTUPINFO siStartupInfo; SECURITY_ATTRIBUTES saProcess, saThread; ZeroMemory( &siStartupInfo, sizeof(siStartupInfo) ); siStartupInfo.cb = sizeof(siStartupInfo); saProcess.nLength = sizeof(saProcess); saProcess.lpSecurityDescriptor = NULL; saProcess.bInheritHandle = true; saThread.nLength = sizeof(saThread); saThread.lpSecurityDescriptor = NULL; saThread.bInheritHandle = true; return ::CreateProcess( NULL, (LPTSTR)pszExeName, &saProcess, &saThread, false, Create_DEFAULT_ERROR_MODE, NULL, NULL, &siStartupInfo, &piProcInfoGPS ); |
|