鱼C论坛

 找回密码
 立即注册
查看: 1862|回复: 3

课后检测点11.4

[复制链接]
发表于 2013-10-31 19:53:10 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
关于pushf和popf的用法
1 mov ax,0
2 push ax
3 popf
4 mov ax,0fff0h
5 add ax,0010h
6 pushf
7 pop ax
8 and al,11000101B
9 and ah,00001000B


pushf:将标志寄存器的值压入栈
popf:从栈中弹出数据,送入标志寄存器
第3行popf 栈中数据送入标志寄存器,标志寄存器有那么多位,送入的是哪位呢?同样的pushf标志寄存器的值指的是什么值?哪一位的?
这两个指令需要说明的是什么问题?有什么作用?不太明白!


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2013-10-31 21:36:02 | 显示全部楼层
标志寄存器有16位,入栈出栈每次操作一个字,也就是16位。不是送入哪一位,而是把EFLAG标志寄存器的值压入栈中。
可参考书的211页的flag寄存器各位示意图
1.jpg

popf后,标志寄存器中,本章节介绍的那些标志位都为0(但是此时标志寄存器并不是所有位置都为0,这个不用关心,没学过的位置用*先代替),向下进行,那么pushf将计算后的当时状态的标志寄存器入栈,然后pop给ax,这是ax是寄存器的值(这个值中包含了我们的*号),接下来就是对那些没有学过的标志位的屏蔽操作,这就是最后两条指令的意义所在,将不确定的位置都归0,那么只剩下我们能够确定的位置了,所以,结果就可以推理出来了。

mov ax,0   

push ax   

popf   

mov ax,0fff0h   

add ax,0010h   

pushf

pop ax               0  0  0  0  of df if tf sf zf 0  af 0  pf 0  cf

                     0  0  0  0  0  0  *  *  0  1  0  *  0  1  0  1

                     ax=flag=000000** 010*0101b

and al,11000101B     al=01000101b=45h

and ah,00001000B     ah=00000000b=0h
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-11-1 18:39:53 | 显示全部楼层

版主你回复的太快了  搞得我们都木有帮助别人的机会{:7_177:}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2013-11-2 12:34:35 | 显示全部楼层
嗯,明白了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-17 12:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表