this指针在汇编中被覆盖

昨天遇到个坑,在调试一个程序的时候,在一个类对象的函数处理过程中,this指针被修改。导致程序崩溃。

我的思路是在汇编中先找出this指针的位置,看究竟是怎么被修改了。参考了以下文章,和自己的调试,发现this指针是作为隐藏参数传递的。

http://blog.csdn.net/chenlycly/article/details/53102120

原来在这个函数内部调用了一个dll的api,这个api的参数在this前push进栈,但这个dll的api修改这个参数时越界了,把this也覆盖了。导致this指针出错。

大概是这样:

参数被写前            在api中参数被修改,覆盖了this

xxxx                         aaaa

xxxx  ----->              aaaa

this                           aaaa

...                              ...

ebp                          ebp

因此,绝对是dll有问题。或者是头文件声明的参数结构太短了。

果然查看了以下是头文件跟dll的版本不对应,新版的头文件参数结构变长了。修改后没问题了。

以后利用第三方dll注意版本!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值