'Объявляем используемые функции Private Declare Function CreateToolhelpSnapshot Lib "Kernel32" Alias "CreateToolhelp32Snapshot" (ByVal lFlags As Long, ByVal lProcessID As Long) As Long Private Declare Function ProcessFirst Lib "Kernel32" Alias "Process32First" (ByVal hSnapShot As Long, uProcess As PROC_INFO) As Long Private Declare Function ProcessNext Lib "Kernel32" Alias "Process32Next" (ByVal hSnapShot As Long, uProcess As PROC_INFO) As Long 'Теперь объявим процедуру. Именно процедуру, а не функцию!!! Private Declare Sub CloseHandle Lib "Kernel32" (ByVal hPass As Long) 'Теперь константы Private Const TH32CS_SNAPPROCESS As Long = 2& Private Const MAX_PATH As Integer = 260 'Теперь наши типы данных Public Type PROC_INFO dwordSize As Long Usage As Long ProcessID As Long DefaultHeapID As Long ModuleID As Long Threads As Long ParentProcessID As Long ClassBase As Long dwordFlags As Long FileSize As String * MAX_PATH End Type 'Public, т.к. в формах и т.д. будет использован этот же тип. Его будем возвращать. 'Теперь функция Public Function GetProcInfo(mInfo As PROC_INFO) As Boolean ' mInfo мы возвращаем ' Это локальные переменные Dim LH_SS As Long Dim currProcess As PROC_INFO Dim RetVal As Long LH_SS = CreateToolhelpSnapshot(TH32CS_SNAPPROCESS, 0&) If LH_SS = 0 Then GetProcInfo = False 'если ошибка, то выдаем негативное значение функции Exit Function End If currProcess.dwordSize = Len(currProcess) 'меряем длину RetVal = ProcessFirst(LH_SS, currProcess) Do While RetVal RetVal = ProcessNext(LH_SS, currProcess) ' заполняем остальные данные Loop CloseHandle LH_SS mInfo = currProcess 'присваиваем значение переменной GetProcInfo = True ' сообщаем о результатах выполнения функции End Function Вот и все. Наверное можно было бы и проще. Да вот не придумал еще. Ах, да. Использование; Dim MyResult as Proc_Inf call GetProcInfo(MyResult)
Ответить
|