10107的错误,是由内存分配及访问不当引起的.
问题原由:
假如用HeapAlloc()分配一段大小为1024字节的内存区.而在后面代码中对这段内存区操作,将它看成大小为1050个字节,内存访问越界,而程序没有报错,后面就引起了一系列问题,如:HeapAlloc分配内存失败,WSASend失败等等,很罕见的问题.
我在自己的同一程序中先后调用2次这个包含WSAStartup的函数,
_SendProc proc _lpUserName,_lpPassword
invoke RtlZeroMemory,addr @stWsadata,sizeof WSADATA
invoke WSAStartup,202h,addr @stWsadata
invoke WSAGetLastError
。。。。。。。
但是第一次成功,第二次却总是失败,查了下错误代码,返回10107,说什么不该发生错误的系统调用发生错误,很是纳闷,上网百度了一下,才知道肯能是内存访问越界问题,因此在我的程序上加了个这样的:
pushad
invoke _Main
popad
invoke _SendProc,addr szNameBuffer,addr Realp
可能是_main中用了ebp这个寄存器做了大量运算导致的加个push和pop就行了
这种错误出现了很难找出原因,所以就靠我们平时多注意了