Вопрос № 22667: Напомните пожалуйста, как проверить, висит процесс в памяти или нет? (ну типа, есть он в окне диспетчера задач)...
Вопрос № 22.667
Напомните пожалуйста, как проверить, висит процесс в памяти или нет? (ну типа, есть он в окне диспетчера задач)
Отправлен: 26.06.2005, 10:34
Вопрос задал: Лунин С.Н. (статус: Посетитель)
Всего ответов отправлено: 1
Отвечает: _Виталий
Здравствуйте, Лунин С.Н.!
Вот пример, как убить процесс по его имени. Переделать его для ваших целей, думаю у вас не возникнит сложностей. Разместите на форме обект LISTBOX с именем lstProc две кнопки с именами cmdLIst, cmdKill
-------------------------------------------
Private Type PROCESSENTRY32
dwSize As Long
cntUsage As Long
th32ProcessID As Long
th32DefaultHeapID As Long
th32ModuleID As Long
cntThreads As Long
th32ParentProcessID As Long
pcPriClassBase As Long
dwFlags As Long
szExeFile As String * 260
End Type
Private Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Private Declare Function TerminateProcess Lib "kernel32" (ByVal hProcess As Long, ByVal uExitCode As Long) As Long
Private Declare Function CreateToolhelpSnapshot Lib "kernel32" Alias "CreateToolhelp32Snapshot" (ByVal lFlags As Long, ByVal lProcessID As Long) As Long
Private Declare Function Process32First Lib "kernel32" (ByVal hSnapShot As Long, uProcess As PROCESSENTRY32) As Long
Private Declare Function Process32Next Lib "kernel32" (ByVal hSnapShot As Long, uProcess As PROCESSENTRY32) As Long
Private Declare Sub CloseHandle Lib "kernel32" (ByVal hPass As Long)
Public Sub ProcessList()
lstProc.Clear
Dim hSnapShot As Long, nProcess As Long
Dim uProcess As PROCESSENTRY32
hSnapShot = CreateToolhelpSnapshot(2, 0)
uProcess.dwSize = LenB(uProcess)
nProcess = Process32First(hSnapShot, uProcess)
Do While nProcess
lstProc.AddItem (LCase(uProcess.szExeFile))
lstProc.ItemData(lstProc.NewIndex) = uProcess.th32ProcessID
nProcess = Process32Next(hSnapShot, uProcess)
Loop
CloseHandle hSnapShot
End Sub
Public Sub KillProc(proc As String)
ProcessList
Dim count As Integer
Dim hProcess As Long
For count = 1 To lstProc.ListCount
If Right(lstProc.List(count - 1), Len(proc)) = proc Then
hProcess = OpenProcess(&H1F0FFF, 1, lstProc.ItemData(count - 1))
TerminateProcess hProcess, 0
End If
Next count
End Sub
Private Sub cmdKill_Click()
KillProc "winamp.exe"
End Sub
Private Sub cmdList_Click()
ProcessList
End Sub
Ответ отправил: _Виталий (статус: 3-ий класс)
Отправлен: 26.06.2005, 18:31 Оценка за ответ: 5 Комментарий оценки: Спасибо, все очень здорово...То, что я хотел слышать.