我没学过汇编,是一个汇编废物。。 我写了这样的一个函数template_WindowProc ![]() 又写了一个类 类里面有个WindowProc函数 ![]() 在类初始化里面申请了一块内存,将template_WindowProc拷贝进这块新内存 在这个新内存里面将变量box(类指针template_WindowProc)和proc(类成员函数WindowProc)的值修改成实际的值 以下是初始化的代码 ![]() 在初始化中调用了拷贝出来的新的template_WindowProc函数 在template_WindowProc函数中再通过以下代码进行调用类中的WindowProc 其中box是this,proc是WindowProc地址 __asm { // 从模板变量中加载类指针 mov eax, [box] mov ecx, eax // 将类实例指针传递到 ECX (this 指针) // 加载成员函数指针 mov eax, [proc] // 将函数调用所需的参数压栈 push lParam push wParam push Msg push hwnd // 调用成员函数 call eax //清理栈 4*4 //add esp, 16 // 将返回值保存到 result mov [result], eax } 调用之后,确实call进了WindowProc,参数应该是 1,2,3,4 但是参数成了2,3,4,第四个参数lParam成了一个未知的数字 当从WindowProc出去之后,回到新的template_WindowProc中,后面还有个call,但call到的地址我跳转看了看,是无效内存,下面划线的是call到无效内存的位置 ![]() 执行过后报错 引发的异常: 0xC0000005: 执行位置 0x02C862B3 时发生访问冲突。 求大佬们看看应该怎么搞 我的本意是拷贝出一个新的函数,当作窗口过程,这个过程调用类成员函数,实现类成员函数窗口过程 |
欢迎光临 精易论坛 (https://125.confly.eu.org/) | Powered by Discuz! X3.4 |