作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 x86 上调试我的代码,问题追溯到 AND 指令如果结果不为零,有时不会清除 ZF 标志。这是有问题的代码:
0257A9F9 mov edx,dword ptr [ecx+18h] 0257A9FC and edx,80000h 0257AA02 int 3 0257AA03 je 0257AA2A
我在 AND 之后添加了一个断点以进行调试。当它停在断点 EDX==0x80000 和 ZF==1 处时。但如果 EDX!=0,ZF 应该被清零。当单步调试器中时,代码工作得非常好,但在正常运行期间它始终失败。
这是一个screenshot调试器 session 。
有什么提示吗?
如果这很重要,代码是由 JIT 生成的,所以我正在执行数据。
提前谢谢您。
最佳答案
谢谢大家。是我的错,抱歉打扰你了。有一个从另一个地方到“int 3”的分支。这就是为什么标志与“int 3”之前的指令不一致的原因。此时我总是对 edx==0x80000 感到困惑。再次抱歉。
关于assembly - x86:ZF 并不总是由 AND 更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/469542/
我是一名优秀的程序员,十分优秀!