标志寄存器02 – 零基础入门学习汇编语言55
第十一章:标志寄存器02
让编程改变世界
Change the world by program
CF标志
flag的第0位是CF,进位标志位。
一般情况下,在进行无符号数运算的时候,它记录了运算结果的最高有效位向更高位的进位值,或从更高位的借位值。
对于位数为N的无符号数来说,其对应的二进制信息的最高位,即第N-1位,的最高有效位,而假想存在的第N位,就是相对于最高有效位的更高位。
进位标志位
我们知道,当两个数据相加的时候,有可能产生从最高有效位向更高位的进位。
比如,两个8 位数据:98H+98H,将产生进位。
由于这个进位值在8位数中无法保存,我们在前面的课程中,就只是简单地说这个进位值丢失了。
其实CPU在运算的时候,并不丢弃这个进位值,而是记录在一个特殊的寄存器的某一位上。
8086CPU 就用flag的CF位来记录这个进位值。
在Debug中,我们可以看到类似下面的信息:
进位标志位
进位标志位
比如,下面的指令:
mov al,98H
add al,al
执行后: (al)=30H,CF=1
CF记录了最高有效位向更高位的进位值
add al,al
执行后: (al)=30H,CF=0,
演示:详细过程请看视频中小甲鱼操作^_^
另外一种情况,而当两个数据做减法的时候,有可能向更高位借位。
比如,两个 8 位数据:97H-98H,将产生借位,借位后,相当于计算197H-98H。
而flag的CF位也可以用来记录这个借位值。
比如,两个 8 位数据:97H-98H,将产生借位,借位后,相当于计算197H-98H。
而flag的CF位也可以用来记录这个借位值。
演示:详细过程请看视频中小甲鱼操作^_^
OF标志
我们先来谈谈溢出的问题。
在进行有符号数运算的时候,如结果超过了机器所能表示的范围称为溢出。
那么,什么是机器所能表示的范围呢?
比如:add al,3 ,那么对于 8 位的有符号数据,机器所能表示的范围就是-128~127。
如果运算结果超出了机器所能表达的范围,将产生溢出。
注意,这里所讲的溢出,只是对有符号数运算而言。(就像进位只是相对于无符号数而言!)
下面我们看两个溢出的例子。
示例一: 相关代码下载
示例二: 相关代码下载
如果在进行有符号数运算时发生溢出,那么运算的结果将不正确。
就上面的两个例子来说:
mov al,98
add al,99
add指令运算的结果是(al)=0C5H ,因为进行的是有符号数运算,所以 al中存储的是有符号数,而0C5H是有符号数-59的补码。
如果我们用add 指令进行的是有符号数运算,则98+99=-59这样的结果让人无法接受。
造成这种情况的原因,就是实际的结果 197,作为一个有符号数,在 8 位寄存器al中存放不下。
由于在进行有符号数运算时,可能发生溢出而造成结果的错误。所以CPU需要对指令执行后是否产生溢出进行记录。因此有了OF~
记住,一定要注意CF和OF的区别:
CF是对无符号数运算有意义的标志位;
而OF是对有符号数运算有意义的标志位。
对于无符号数运算,CPU用CF位来记录是否产生了进位;
对于有符号数运算,CPU 用 OF 位来记录是否产生了溢出,当然,还要用SF位来记录结果的符号。
计算机连他妈妈是谁都不知道
对于有无符号,计算机是分不清楚状况的,因此他必须两种都记载着,要怎么用,看的是你当他是什么!
例如:
mov al, 98d
add al, 99d
对于无符号数运算,98+99没有进位,CF=0
对于有符号数运算,98+99发生溢出,OF=1
adc指令
adc是带进位加法指令 ,它利用了CF位上记录的进位值。
格式:adc 操作对象1,操作对象2
功能:操作对象1=操作对象1+操作对象2+CF
比如:adc ax,bx 实现的功能是:(ax) = (ax) + (bx) + CF
adc指令执行过程演示:
-->
-->
adc指令示例(一)
mov ax,2
mov bx,1
sub bx,ax
adc ax,l
执行后,(ax)=4。
adc执行时,相当于计算: (ax) + 1 + CF = 2 + 1 + 1 = 4
adc指令示例(二)
mov ax,1
add ax,ax
adc ax,3
执行后,(ax)=5
adc执行时,相当于计算: (ax) + 3 + CF = 2 + 3 + 0 = 5
adc指令示例(三)
mov al,98H
add al,al
adc al,3
执行后,(ax)=34H
adc执行时,相当于计算: (ax) + 3 + CF = 30H + 3 + 1 = 34H
在执行 adc 指令的时候加上的 CF 的值的含义,由 adc指令前面的指令决定的,也就是说,关键在于所加上的CF值是被什么指令设置的。
显然,如果CF 的值是被sub指令设置的,那么它的含义就是借位值;如果是被add指令设置的,那么它的含义就是进位值。
我们来看一下两个数据:0198H和0183H如何相加的:
0198H和0183H如何相加的
可以看出,加法可以分两步来进行:
(1)低位相加;
(2)高位相加再加上低位相加产生的进位值。
下面的指令和add ax , bx具有相同的结果:add al,bl adc ah,bh
看来CPU提供 adc 指令的目的,就是来进行加法的第二步运算的。
adc指令和add指令相配合就可以对更大的数据进行加法运算。
编程任务
编程计算1EF000H + 201000H
结果放在ax(高16位)和 bx(低16位)中。
视频下载
技术, IT技术, 汇编语言, 视频教程
风险提示及免责条款
市场有风险,投资需谨慎。本文不构成个人投资建议,也未考虑到个别用户特殊的投资目标、财务状况或需要。用户应考虑本文中的任何意见、观点或结论是否符合其特定状况。据此投资,责任自负。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!