双字节求补为啥可以直接用CPL指令

1.双字节数取补码
功能:(R4 R5)取补码—>(R4 R5)
例:
START: MOV A , R5 ;低4位取值 R5—>A()
CPL A ;低4位取反
ADD A , #01H ;A反码加1(若溢出Cy=1,否则Cy=0)
MOV R5, A ;存放低4位补码 A()—>R5
MOV A , R4 ;高4位取值 R4—>A()
CPL A ;高4位取反
ADDC A , #0 ;A反码加Cy(若溢出Cy=1,否则Cy=0)
MOV R4, A ;存放高4位补码 A()—>R4
END ;结束

求补数不是应该符号位保持不变再取反吗?,这里直接使用CPL指令,不是连符号位也取反了吗
例如求 10000001的补码,除符号位取反:11111110 (反码),+1:11111111 (这是我理解的)
如果按程序来,直接CLP:01111110,+1:01111111
这明显符号位差了吧

有没有人讲一下

您提出的问题是正确的,在一般的计算机系统中,求补数的正确做法是将数字先取反(即对每一位取反),再加上 1。然而在一些特殊情况下,可以使用 CPL(complement)指令来直接取反一个数字,而不需要再加上 1。这种情况下,当被求补数的数字是有符号数时,在取反之前要将其先取绝对值。

在这个例子中,高位和低位的补码都是通过取反后加上 1 来得到的,并不是使用 CPL 指令直接取反。