我并不真正理解SetWindowsHookEx()的文档。我知道应该在第一个论点中加入什么,但对于第二个、第三个和第四个论点,我感到困惑。
第二个参数是HOOKPROC,它就像一个普通的windows进程吗?
对于第三和第四个,我不理解它们。你们能给我解释一下吗?谢谢
发布于 2011-05-09 10:21:55
Windows API文档比这里的任何人都更好地解释了所有参数:http://msdn.microsoft.com/en-us/library/ms644990(v=vs.85).aspx
第二个参数要么为NULL,要么是指向HOOKPROC的指针。请注意,“如果dwThreadId参数为零或指定了由不同进程创建的线程的标识符,则lpfn参数必须指向DLL中的钩子过程。否则,lpfn可以指向与当前进程关联的代码中的钩子过程。”下面是一个来自MSDN的HOOKPROC示例:
LRESULT CALLBACK HookProc(
int nCode,
WPARAM wParam,
LPARAM lParam
)
{
// process event
...
return CallNextHookEx(NULL, nCode, wParam, lParam);
}如果参数指定了由当前进程创建的线程,并且钩子过程位于与当前进程关联的代码中,则dwThreadId第三个参数必须设置为NULL。
fourth是“钩子程序要与之关联的线程的标识符。如果此参数为零,则钩子程序与与调用线程运行在同一桌面上的所有现有线程相关联。”
https://stackoverflow.com/questions/5931864
复制相似问题