汇编减法指令产生借位时是如何实现让CF置1的? 10
已经知道计算机里只有加法器,没有减法器。减法是化作补码的加法运算来实现的。那么做减法运算时借位标志CF是否被置1,应该是根据操作数的补码的加法运算结果是否产生进位来决定的...
已经知道计算机里只有加法器,没有减法器。减法是化作补码的加法运算来实现的。那么做减法运算时借位标志CF是否被置1,应该是根据操作数的补码的加法运算结果是否产生进位来决定的。
然后我发现一个奇怪的问题,汇编指令如下:
CLC (清空CF,CF=0)
MOV DX,8234H
MOV AX,01EEH (AX=01EEH , CF=0)
SUB AX,4491H (AX=BD5DH , CF=1)
SBB DX,8000H (DX=1468H , CF=0)
然后我按照模拟计算机里的补码运算来操作了一便。
01EEH化成二进制为:0000 0001 1110 1110
4491H化成二进制为:0100 0100 1001 0001
上面两个都是真值,按照补码运算原理,X-Y = X + [-Y]补。
所以0000 0001 1110 1110的原码为 0000 0001 1110 1110,补码为 0000 0001 1110 1110
-0100 0100 1001 0001的原码为 1100 0100 1001 0001,补码为 1011 1011 0110 1111。
所以01EEH-4491H在计算机的运算是如下的补码运算:
0000 0001 1110 1110
+ 1011 1011 0110 1111
------------------------
1011 1101 0101 1101
结果确实是BD5DH,但问题也随之来了,这个运算结果的最高位并没有产生进位,也就是CF标志位并没有被置1。那上面汇编语句里的倒数第二句括号里的注释却是CF=1。当然理论上01EEH-4491H确实要借位(CF要被置1),但按上面运算过程来看,CF却没有被置1。那实际过程中CF里的哪个1到底是怎么弄上去的呢?小弟水平有限,麻烦哪位民间高手解我疑惑?(说明一下,上面的汇编语句没有问题) 展开
然后我发现一个奇怪的问题,汇编指令如下:
CLC (清空CF,CF=0)
MOV DX,8234H
MOV AX,01EEH (AX=01EEH , CF=0)
SUB AX,4491H (AX=BD5DH , CF=1)
SBB DX,8000H (DX=1468H , CF=0)
然后我按照模拟计算机里的补码运算来操作了一便。
01EEH化成二进制为:0000 0001 1110 1110
4491H化成二进制为:0100 0100 1001 0001
上面两个都是真值,按照补码运算原理,X-Y = X + [-Y]补。
所以0000 0001 1110 1110的原码为 0000 0001 1110 1110,补码为 0000 0001 1110 1110
-0100 0100 1001 0001的原码为 1100 0100 1001 0001,补码为 1011 1011 0110 1111。
所以01EEH-4491H在计算机的运算是如下的补码运算:
0000 0001 1110 1110
+ 1011 1011 0110 1111
------------------------
1011 1101 0101 1101
结果确实是BD5DH,但问题也随之来了,这个运算结果的最高位并没有产生进位,也就是CF标志位并没有被置1。那上面汇编语句里的倒数第二句括号里的注释却是CF=1。当然理论上01EEH-4491H确实要借位(CF要被置1),但按上面运算过程来看,CF却没有被置1。那实际过程中CF里的哪个1到底是怎么弄上去的呢?小弟水平有限,麻烦哪位民间高手解我疑惑?(说明一下,上面的汇编语句没有问题) 展开
3个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |