为什么奇偶校验标志为 1 而奇偶校验标志为奇数

问题描述

执行以下两条指令后:

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。