ホーム › System.Threading › SetTimerQueueTimer
SetTimerQueueTimer
関数タイマーキューにコールバック付きタイマーを設定する。
シグネチャ
// KERNEL32.dll
#include <windows.h>
HANDLE SetTimerQueueTimer(
HANDLE TimerQueue, // optional
WAITORTIMERCALLBACK Callback,
void* Parameter, // optional
DWORD DueTime,
DWORD Period,
BOOL PreferIo
);パラメーター
| 名前 | 型 | 方向 |
|---|---|---|
| TimerQueue | HANDLE | inoptional |
| Callback | WAITORTIMERCALLBACK | in |
| Parameter | void* | inoptional |
| DueTime | DWORD | in |
| Period | DWORD | in |
| PreferIo | BOOL | in |
戻り値の型: HANDLE
各言語での呼び出し定義
// KERNEL32.dll
#include <windows.h>
HANDLE SetTimerQueueTimer(
HANDLE TimerQueue, // optional
WAITORTIMERCALLBACK Callback,
void* Parameter, // optional
DWORD DueTime,
DWORD Period,
BOOL PreferIo
);[DllImport("KERNEL32.dll", ExactSpelling = true)]
static extern IntPtr SetTimerQueueTimer(
IntPtr TimerQueue, // HANDLE optional
IntPtr Callback, // WAITORTIMERCALLBACK
IntPtr Parameter, // void* optional
uint DueTime, // DWORD
uint Period, // DWORD
bool PreferIo // BOOL
);<DllImport("KERNEL32.dll", ExactSpelling:=True)>
Public Shared Function SetTimerQueueTimer(
TimerQueue As IntPtr, ' HANDLE optional
Callback As IntPtr, ' WAITORTIMERCALLBACK
Parameter As IntPtr, ' void* optional
DueTime As UInteger, ' DWORD
Period As UInteger, ' DWORD
PreferIo As Boolean ' BOOL
) As IntPtr
End Function' TimerQueue : HANDLE optional
' Callback : WAITORTIMERCALLBACK
' Parameter : void* optional
' DueTime : DWORD
' Period : DWORD
' PreferIo : BOOL
Declare PtrSafe Function SetTimerQueueTimer Lib "kernel32" ( _
ByVal TimerQueue As LongPtr, _
ByVal Callback As LongPtr, _
ByVal Parameter As LongPtr, _
ByVal DueTime As Long, _
ByVal Period As Long, _
ByVal PreferIo As Long) As LongPtr
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。import ctypes
from ctypes import wintypes
SetTimerQueueTimer = ctypes.windll.kernel32.SetTimerQueueTimer
SetTimerQueueTimer.restype = ctypes.c_void_p
SetTimerQueueTimer.argtypes = [
wintypes.HANDLE, # TimerQueue : HANDLE optional
ctypes.c_void_p, # Callback : WAITORTIMERCALLBACK
ctypes.POINTER(None), # Parameter : void* optional
wintypes.DWORD, # DueTime : DWORD
wintypes.DWORD, # Period : DWORD
wintypes.BOOL, # PreferIo : BOOL
]require 'fiddle'
require 'fiddle/import'
lib = Fiddle.dlopen('KERNEL32.dll')
SetTimerQueueTimer = Fiddle::Function.new(
lib['SetTimerQueueTimer'],
[
Fiddle::TYPE_VOIDP, # TimerQueue : HANDLE optional
Fiddle::TYPE_VOIDP, # Callback : WAITORTIMERCALLBACK
Fiddle::TYPE_VOIDP, # Parameter : void* optional
-Fiddle::TYPE_INT, # DueTime : DWORD
-Fiddle::TYPE_INT, # Period : DWORD
Fiddle::TYPE_INT, # PreferIo : BOOL
],
Fiddle::TYPE_VOIDP)#[link(name = "kernel32")]
extern "system" {
fn SetTimerQueueTimer(
TimerQueue: *mut core::ffi::c_void, // HANDLE optional
Callback: *const core::ffi::c_void, // WAITORTIMERCALLBACK
Parameter: *mut (), // void* optional
DueTime: u32, // DWORD
Period: u32, // DWORD
PreferIo: i32 // BOOL
) -> *mut core::ffi::c_void;
}
// crates: windows-sys provides ready-made bindings for this API.$sig = @"
[DllImport("KERNEL32.dll")]
public static extern IntPtr SetTimerQueueTimer(IntPtr TimerQueue, IntPtr Callback, IntPtr Parameter, uint DueTime, uint Period, bool PreferIo);
"@
$api = Add-Type -MemberDefinition $sig -Name 'KERNEL32_SetTimerQueueTimer' -Namespace Win32 -PassThru
# $api::SetTimerQueueTimer(TimerQueue, Callback, Parameter, DueTime, Period, PreferIo)#uselib "KERNEL32.dll"
#func global SetTimerQueueTimer "SetTimerQueueTimer" sptr, sptr, sptr, sptr, sptr, sptr
; SetTimerQueueTimer TimerQueue, Callback, Parameter, DueTime, Period, PreferIo ; 戻り値は stat
; TimerQueue : HANDLE optional -> "sptr"
; Callback : WAITORTIMERCALLBACK -> "sptr"
; Parameter : void* optional -> "sptr"
; DueTime : DWORD -> "sptr"
; Period : DWORD -> "sptr"
; PreferIo : BOOL -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。#uselib "KERNEL32.dll"
#cfunc global SetTimerQueueTimer "SetTimerQueueTimer" sptr, sptr, sptr, int, int, int
; res = SetTimerQueueTimer(TimerQueue, Callback, Parameter, DueTime, Period, PreferIo)
; TimerQueue : HANDLE optional -> "sptr"
; Callback : WAITORTIMERCALLBACK -> "sptr"
; Parameter : void* optional -> "sptr"
; DueTime : DWORD -> "int"
; Period : DWORD -> "int"
; PreferIo : BOOL -> "int"; HANDLE SetTimerQueueTimer(HANDLE TimerQueue, WAITORTIMERCALLBACK Callback, void* Parameter, DWORD DueTime, DWORD Period, BOOL PreferIo)
#uselib "KERNEL32.dll"
#cfunc global SetTimerQueueTimer "SetTimerQueueTimer" intptr, intptr, intptr, int, int, int
; res = SetTimerQueueTimer(TimerQueue, Callback, Parameter, DueTime, Period, PreferIo)
; TimerQueue : HANDLE optional -> "intptr"
; Callback : WAITORTIMERCALLBACK -> "intptr"
; Parameter : void* optional -> "intptr"
; DueTime : DWORD -> "int"
; Period : DWORD -> "int"
; PreferIo : BOOL -> "int"import (
"golang.org/x/sys/windows"
"unsafe"
)
var (
kernel32 = windows.NewLazySystemDLL("KERNEL32.dll")
procSetTimerQueueTimer = kernel32.NewProc("SetTimerQueueTimer")
)
// TimerQueue (HANDLE optional), Callback (WAITORTIMERCALLBACK), Parameter (void* optional), DueTime (DWORD), Period (DWORD), PreferIo (BOOL)
r1, _, err := procSetTimerQueueTimer.Call(
uintptr(TimerQueue),
uintptr(Callback),
uintptr(Parameter),
uintptr(DueTime),
uintptr(Period),
uintptr(PreferIo),
)
_ = err // syscall.Errno (valid when the call sets last-error)
_ = r1 // HANDLEfunction SetTimerQueueTimer(
TimerQueue: THandle; // HANDLE optional
Callback: Pointer; // WAITORTIMERCALLBACK
Parameter: Pointer; // void* optional
DueTime: DWORD; // DWORD
Period: DWORD; // DWORD
PreferIo: BOOL // BOOL
): THandle; stdcall;
external 'KERNEL32.dll' name 'SetTimerQueueTimer';result := DllCall("KERNEL32\SetTimerQueueTimer"
, "Ptr", TimerQueue ; HANDLE optional
, "Ptr", Callback ; WAITORTIMERCALLBACK
, "Ptr", Parameter ; void* optional
, "UInt", DueTime ; DWORD
, "UInt", Period ; DWORD
, "Int", PreferIo ; BOOL
, "Ptr") ; return: HANDLE●SetTimerQueueTimer(TimerQueue, Callback, Parameter, DueTime, Period, PreferIo) = DLL("KERNEL32.dll", "void* SetTimerQueueTimer(void*, void*, void*, dword, dword, bool)")
# 呼び出し: SetTimerQueueTimer(TimerQueue, Callback, Parameter, DueTime, Period, PreferIo)
# TimerQueue : HANDLE optional -> "void*"
# Callback : WAITORTIMERCALLBACK -> "void*"
# Parameter : void* optional -> "void*"
# DueTime : DWORD -> "dword"
# Period : DWORD -> "dword"
# PreferIo : BOOL -> "bool"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。