课后检测点11.4
关于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标志寄存器的值指的是什么值?哪一位的?
这两个指令需要说明的是什么问题?有什么作用?不太明白!
标志寄存器有16位,入栈出栈每次操作一个字,也就是16位。不是送入哪一位,而是把EFLAG标志寄存器的值压入栈中。
可参考书的211页的flag寄存器各位示意图
popf后,标志寄存器中,本章节介绍的那些标志位都为0(但是此时标志寄存器并不是所有位置都为0,这个不用关心,没学过的位置用*先代替),向下进行,那么pushf将计算后的当时状态的标志寄存器入栈,然后pop给ax,这是ax是寄存器的值(这个值中包含了我们的*号),接下来就是对那些没有学过的标志位的屏蔽操作,这就是最后两条指令的意义所在,将不确定的位置都归0,那么只剩下我们能够确定的位置了,所以,结果就可以推理出来了。
mov ax,0
push ax
popf
mov ax,0fff0h
add ax,0010h
pushf
pop ax 0000of df if tf sf zf 0af 0pf 0cf
000000**010*0101
ax=flag=000000** 010*0101b
and al,11000101B al=01000101b=45h
and ah,00001000B ah=00000000b=0h 福禄娃娃 发表于 2013-10-31 21:36 static/image/common/back.gif
标志寄存器有16位,入栈出栈每次操作一个字,也就是16位。不是送入哪一位,而是把EFLAG标志寄存器的值压入栈 ...
版主你回复的太快了搞得我们都木有帮助别人的机会{:7_177:} 嗯,明白了。
页:
[1]