问题描述
执行以下两条指令后:
MOV BX,0FD51H
DEC BX
我得到奇偶校验标志 = 1(表示偶数个)
但是,递减值的二进制表示是:
1111 1101 0101 0000
它有 9 个 1(即奇数个 1)。
此外,在此之后执行 NEG BX
会导致 PF = 0。但是,2 的补码是:
0000 0010 1011 0000
有偶数个。所以我期望 PF = 1。
解决方法
来自英特尔的手册(第 3.4.3.1 节 状态标志):
Parity flag — 如果结果的最低有效字节包含偶数个 1 位,则设置; 否则清除。
DEC BX
之后的最低有效字节是 50h(即 1010000b),它有偶数个 1。所以你会得到 PF=1。
同样,在 NEG
之后,最低有效字节是 B0h (10110000b),它有奇数个 1。所以你得到 PF=0。