检测点11.4 :下面程序执行后,(ax)= ?
mov ax,0
push ax
popf
mov ax,0fff0H
add ax,0010H
pushf
pop ax
and al,11000101B
and ah,00001000B
DOSBOX 实际运行得到 (ax) = 0045H
DOSBOX 实际运行得到 (ax) = 0045H
解析
- pushf 与 popf
pushf 将标志寄存器的值压栈
popf 是从栈中弹出数据,送入标志寄存器
- 标志符全部置为零
mov ax,0
ax = 0000 0000 0000 0000B
push ax
popf
---------------------------------------------------------------
15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00
OF DF IF TF SF ZF AF PF CF
---------------------------------------------------------------
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
感受一下,此刻所有的标志位都被置为0了
- 部分标志符在add ax,0010H pushf之后发生改变
mov ax,0fff0H
add ax,0010H
pushf
进行无符号运算
ax
= fff0H+0010H
= 1111 1111 1111 0000 B + 0000 0000 0001 0000B
= (进位1)0000 0000 0000 0000 0000B
CF = 1
进行有符号运算
fff0H 是负数 补码为 1000 0000 0000 1111B + 1 = 1000 0000 0001 0000B = -16D
0010H 是正数 为 16D
-16D + 16D = 0
16位可以表示的范围是 - 32768~32767
0 在范围之内,不会溢出
OF = 0
零个(偶数个一) PF = 1
全是零 ZF = 1
把这些标志符全部写好
无法判断的标志符写上问号 ?
---------------------------------------------------------------
15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00
OF DF IF TF SF ZF AF PF CF
---------------------------------------------------------------
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 ? ? 0 1 0 ? 0 1 0 1
- 最后计算 (ax)
pop ax
ax
= 0 0 0 0 0 0 ? ? 0 1 0 ? 0 1 0 1 B
(四个四个整理一下)
= 0000 00?? 010? 0101 B
ax
------
ah|al
al = 010? 0101 B
ah = 0000 00?? B
and al,11000101B
010? 0101 B
1100 0101 B
and
----------------------
0100 0101 B
4 5 H
and ah,00001000B
0000 00?? B
0000 1000 B
and
-----------------------
0000 0000 B
0 0 H
(ax) = ah | al = 00 45 H