Win32 API 日本語リファレンス
ホームSystem.ProcessStatus › EnumProcessModules

EnumProcessModules

関数
指定プロセスにロードされたモジュールのハンドルを列挙する。
DLLPSAPI.dll呼出規約winapiSetLastErrorあり対応OSWindows XP 以降

シグネチャ

// PSAPI.dll
#include <windows.h>

BOOL EnumProcessModules(
    HANDLE hProcess,
    HMODULE* lphModule,
    DWORD cb,
    DWORD* lpcbNeeded
);

パラメーター

名前方向
hProcessHANDLEin
lphModuleHMODULE*out
cbDWORDin
lpcbNeededDWORD*out

戻り値の型: BOOL

各言語での呼び出し定義

// PSAPI.dll
#include <windows.h>

BOOL EnumProcessModules(
    HANDLE hProcess,
    HMODULE* lphModule,
    DWORD cb,
    DWORD* lpcbNeeded
);
[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("PSAPI.dll", SetLastError = true, ExactSpelling = true)]
static extern bool EnumProcessModules(
    IntPtr hProcess,   // HANDLE
    IntPtr lphModule,   // HMODULE* out
    uint cb,   // DWORD
    out uint lpcbNeeded   // DWORD* out
);
<DllImport("PSAPI.dll", SetLastError:=True, ExactSpelling:=True)>
Public Shared Function EnumProcessModules(
    hProcess As IntPtr,   ' HANDLE
    lphModule As IntPtr,   ' HMODULE* out
    cb As UInteger,   ' DWORD
    <Out> ByRef lpcbNeeded As UInteger   ' DWORD* out
) As Boolean
End Function
' hProcess : HANDLE
' lphModule : HMODULE* out
' cb : DWORD
' lpcbNeeded : DWORD* out
Declare PtrSafe Function EnumProcessModules Lib "psapi" ( _
    ByVal hProcess As LongPtr, _
    ByVal lphModule As LongPtr, _
    ByVal cb As Long, _
    ByRef lpcbNeeded As Long) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

EnumProcessModules = ctypes.windll.psapi.EnumProcessModules
EnumProcessModules.restype = wintypes.BOOL
EnumProcessModules.argtypes = [
    wintypes.HANDLE,  # hProcess : HANDLE
    ctypes.c_void_p,  # lphModule : HMODULE* out
    wintypes.DWORD,  # cb : DWORD
    ctypes.POINTER(wintypes.DWORD),  # lpcbNeeded : DWORD* out
]
# GetLastError: use ctypes.GetLastError() (or ctypes.WinDLL(use_last_error=True))
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('PSAPI.dll')
EnumProcessModules = Fiddle::Function.new(
  lib['EnumProcessModules'],
  [
    Fiddle::TYPE_VOIDP,  # hProcess : HANDLE
    Fiddle::TYPE_VOIDP,  # lphModule : HMODULE* out
    -Fiddle::TYPE_INT,  # cb : DWORD
    Fiddle::TYPE_VOIDP,  # lpcbNeeded : DWORD* out
  ],
  Fiddle::TYPE_INT)
#[link(name = "psapi")]
extern "system" {
    fn EnumProcessModules(
        hProcess: *mut core::ffi::c_void,  // HANDLE
        lphModule: *mut *mut core::ffi::c_void,  // HMODULE* out
        cb: u32,  // DWORD
        lpcbNeeded: *mut u32  // DWORD* out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[return: MarshalAs(UnmanagedType.Bool)]
[DllImport("PSAPI.dll", SetLastError = true)]
public static extern bool EnumProcessModules(IntPtr hProcess, IntPtr lphModule, uint cb, out uint lpcbNeeded);
"@
$api = Add-Type -MemberDefinition $sig -Name 'PSAPI_EnumProcessModules' -Namespace Win32 -PassThru
# $api::EnumProcessModules(hProcess, lphModule, cb, lpcbNeeded)
#uselib "PSAPI.dll"
#func global EnumProcessModules "EnumProcessModules" sptr, sptr, sptr, sptr
; EnumProcessModules hProcess, lphModule, cb, varptr(lpcbNeeded)   ; 戻り値は stat
; hProcess : HANDLE -> "sptr"
; lphModule : HMODULE* out -> "sptr"
; cb : DWORD -> "sptr"
; lpcbNeeded : DWORD* out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "PSAPI.dll"
#cfunc global EnumProcessModules "EnumProcessModules" sptr, sptr, int, var
; res = EnumProcessModules(hProcess, lphModule, cb, lpcbNeeded)
; hProcess : HANDLE -> "sptr"
; lphModule : HMODULE* out -> "sptr"
; cb : DWORD -> "int"
; lpcbNeeded : DWORD* out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; BOOL EnumProcessModules(HANDLE hProcess, HMODULE* lphModule, DWORD cb, DWORD* lpcbNeeded)
#uselib "PSAPI.dll"
#cfunc global EnumProcessModules "EnumProcessModules" intptr, intptr, int, var
; res = EnumProcessModules(hProcess, lphModule, cb, lpcbNeeded)
; hProcess : HANDLE -> "intptr"
; lphModule : HMODULE* out -> "intptr"
; cb : DWORD -> "int"
; lpcbNeeded : DWORD* out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	psapi = windows.NewLazySystemDLL("PSAPI.dll")
	procEnumProcessModules = psapi.NewProc("EnumProcessModules")
)

// hProcess (HANDLE), lphModule (HMODULE* out), cb (DWORD), lpcbNeeded (DWORD* out)
r1, _, err := procEnumProcessModules.Call(
	uintptr(hProcess),
	uintptr(lphModule),
	uintptr(cb),
	uintptr(lpcbNeeded),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // BOOL
function EnumProcessModules(
  hProcess: THandle;   // HANDLE
  lphModule: Pointer;   // HMODULE* out
  cb: DWORD;   // DWORD
  lpcbNeeded: Pointer   // DWORD* out
): BOOL; stdcall;
  external 'PSAPI.dll' name 'EnumProcessModules';
result := DllCall("PSAPI\EnumProcessModules"
    , "Ptr", hProcess   ; HANDLE
    , "Ptr", lphModule   ; HMODULE* out
    , "UInt", cb   ; DWORD
    , "Ptr", lpcbNeeded   ; DWORD* out
    , "Int")   ; return: BOOL
●EnumProcessModules(hProcess, lphModule, cb, lpcbNeeded) = DLL("PSAPI.dll", "bool EnumProcessModules(void*, void*, dword, void*)")
# 呼び出し: EnumProcessModules(hProcess, lphModule, cb, lpcbNeeded)
# hProcess : HANDLE -> "void*"
# lphModule : HMODULE* out -> "void*"
# cb : DWORD -> "dword"
# lpcbNeeded : DWORD* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。