我有一个32位应用程序需要将64位窗口长值设置为属于64位进程的窗口。当我尝试从32位进程调用SetWindowLong时,只设置了64位值的低位双字(我在调试64位进程时看到它),显然只有64位值的低位双字返回到调用者(因为函数返回LONG,它是32位值)。32位版本的user32.dll中未导出函数SetWindowLongPtr。我试图反汇编SetWindowLongPtr源代码以查看它是否只是系统调用之上的某个层,但该函数实际上很大并且调用了其他几个未记录的函数。如何从32位进程设置64位窗口长值?将32位应用重建为x64目标不是一种选择。 最佳答案
我还在为钩子(Hook)而苦苦挣扎。我的目标是:在notepad.exe中设置一个钩子(Hook)对其进行子类化(我的最终目标是将Edit类子类化并在我自己的窗口中显示内容)免责声明:我知道有更简单的方法可以从记事本中获取文本/内容,但这是我学习C、winapi、子类化和Hook的一种方式。我的问题是SetWindowLongPtr始终返回ERROR_ACCESS_DENIED错误(代码5)。2013年5月22日:已修复!问题是SetWindowLongPtr在错误的地方。它必须在GetMsgProc函数内。问题变得有点冗长和困惑,所以我重新写了问题(更新了代码)现在的问题是,当目标是
关于MSDN网站,我发现以下内容:CallingSetWindowLongPtrwiththeGWLP_WNDPROCindexcreatesasubclassofthewindowclassusedtocreatethewindow.Anapplicationcansubclassasystemclass,butshouldnotsubclassawindowclasscreatedbyanotherprocess.TheSetWindowLongPtrfunctioncreatesthewindowsubclassbychangingthewindowprocedureassoci
我想P/Invoke到GetWindowLongPtr和SetWindowLongPtr,而且我看到了关于它们的相互矛盾的信息。一些消息称,在32位平台上,GetWindowLongPtr只是一个调用GetWindowLong的预处理器宏,而GetWindowLongPtr并不作为user32.dll中的入口点存在。例如:pinvoke.netentryforSetWindowLongPtr有一个检查IntPtr.Size的静态方法,然后调用SetWindowLong或SetWindowLongPtr,并附有一条评论说“遗留操作系统不支持SetWindowLongPtr”。没有解释“遗