标志寄存器PSW中CF、OF的
汇编跳转指令
操作码
伪码指令
含义
EBcb
JMP rel8
相对短跳转(8位),使rel8处的代码位下一条指令
E9cw
JMP rel16
相对跳转(16位),使rel16处的代码位下一条指令
FF/4
JMP r/m16
绝对跳转(16位),下一指令地址在r/m16中给出
FF/4
JMP r/m32
绝对跳转(32位),下一指令地址在r/m32中给出
0F 8Dcw/cd
JGE rel16/32
大于等于
near
(SF=OF)
0F 8Ccw/cd
JL rel16/32
小于
near
(SF<>OF)
0F 8Ecw/cd
JLE rel16/32
小于等于
near
(ZF=1 or SF<>OF)
0F 86cw/cd
JNA rel16/32
不大于
near
(CF=1 or ZF=1)
0F 85cw/cd
JNZ rel16/32
非零(不等于)
near
(ZF=0)
0F 80cw/cd
JO rel16/32
溢出
near
(OF=1)
0F 8Acw/cd
JP rel16/32
偶数
near
(PF=1)
0F 8Acw/cd
JPE rel16/32
偶数
near
(PF=1)
0F 8Bcw/cd
JPO rel16/32
0F 8Fcw/cd
JNLE rel16/32
不小于等于
near
汇编语言标志位(CF)及一些常用指令
汇编语言标志位(CF)及一些常用指令英文翻译:carry 进位 flag标志NV: no overflow OV: overflowUP: up DN:downDI: disable interrupt EI: enable interruptPL: plus NG: negativeNZ: no zero ZR: zeroNA: no assistant carry AC: assistant carryPO: parity odd PE: parity even 奇偶校验NC: no carry CY: carry汇编标志位:标志名标志 1 标志 0 OF (溢出标志) OV NVDF (方向标志) UP DNIF (中断标志) DI EISF (符号标志位) PL NGZF (零标志) NZ ZRAF (辅助进位标志位) NA ACPF (奇偶标志) PO PECF (进位标志) NC CYOF 溢出(是/否) OV OVerflow NV Not oVerflowDF 方向(减量/增量) DN DowN UP UPIF 中断(允许/关闭) EI Enable Interrupt DI Disable InterruptSF 符号(负/正) NG NeGative PL PLusZF 零(是/否) ZR ZeRo NZ Not ZeroAF 辅助进位(是/否) AC Auxiliary Carry NA Not AuxiliaryPF 奇偶(是/否) PE Parity Even PO Parity OddCF 进位(是/否) CY CarrY NC Not Carry英文解释:NV: no overflow OV: overflowUP: up DN:downDI: disable interrupt EI: enable interruptPL: plus NG: negativeNZ: no zero ZR: zeroNA: no assistant carry AC: assistant carryPO: parity odd PE: parity evenNC: no carry CY: carry先熟悉一下FLAGS标志位:OV、NV即溢出标志位OF=1或0,表示运算结果有无溢出。
标志寄存器PSW中CF、OF的
CF在算术运算中的应用
判断溢出
在进行有符号数加法或减法运算 时,如果CF标志为1且最高位(符 号位)相同,则表示溢出。
进位传播
在进行多位数加法或减法运算时, CF标志用于传播进位或借位,以 确保结果的正确性。
精确计算
通过结合CF标志和其他寄存器, 可以实现更精确的算术运算,例 如二进制数的加法或减法运算。
05
总结
CF和OF的重要性
01
CF(进位标志)的重要性
02
用于整数运算的进位控制。
03
在二进制加法中,如果最高位有进位,CF标志会被 设置。
CF和OF的重要性
01 在执行除法时,余数的符号可以通过CF来判断。
02
OF(溢出标志)的重要性
03
用于检测整数溢出。
CF和OF的重要性
当运算结果超出了整数类型的表示范 围时,OF标志会被设置。
THANKS
感谢观看
CF和OF的使用场景
CF的使用场景
在进行加法或减法运算时,可以使用CF 标志来判断是否产生了进位或借位,从 而进行相应的处理。例如,在二进制加 法中,可以使用CF标志来判断是否需要 进位。
VS
OF的使用场景
在进行算术运算时,可以使用OF标志来判 断是否发生了溢出。如果OF标志为1,则 表示运算结果超出了目标数据类型的表示 范围,需要进行相应的处理。例如,在进 行整数除法时,可以使用OF标志来判断是 否发生了溢出。
决定是否继续进行算术运算
02
根据CF标志的状态,可以判断是否需要继续进行加法或减法运
算,以得到精确结果。
用于二进制数的移位操作
03
在进行二进制数的移位操作时,CF标志可以用来指示移位后最
微机原理习题解答
微机原理习题解答第1章汇编语言基础知识习题解答1.1 什么是汇编语言?汇编语言的特点是什么?;答:为了克服机器语言难以记忆、表达和阅读的缺点,人们采用具有一定含义的符号作为助忆符,用指令助忆符、符号地址等组成的符号指令称为汇编格式指令(或汇编指令)。
汇编语言是汇编指令集、伪指令集和使用它们规则的统称。
汇编语言的特点是:(1)执行速度快。
(2)程序短小。
(3)可以直接控制硬件。
(4)可以方便地编译。
(5)辅助计算机工作者掌握计算机体系结构。
(6)程序编制耗时,可读性差。
(7)程序可移植性差。
1.2 把下列十进制数转换成二进制数、八进制数、十六进制数。
① 127 ② 1021 ③ 0.875 ④ 6.25答:① 1111111B;177Q;7FH ② 1111111101;1775Q;3FDH③ 0.111 B;0.7Q;0.EH ④ 110.01B;6.2Q;6.4H1.3把下列二进制数转换成十进制数。
① 1001.11 ② 101011.10011 ③ 111.011 ④ 1011.1答:① 9.75D ② 43.59375D ③ 7.375D ④ 11.5D1.4 把下列八进制数转换成十进制数。
① 573.06 ② 75.23 ③ 431.7 ④ 123.45答:① 379.09375D ② 61.296875D ③ 281.875 ④ 83.5781251.5 把下列十六进制数转换成十进制数。
① 0D5.F4 ② 8BA.7C ③ 0B2E.3A ④ 6EC.2D答:① 213.953125D ② 2234.484375 ③ 2862.2265625 ④ 1772.175781251.6 把下列英文单词转换成ASCII编码的字符串。
① Upper ② Blow ③ Computer ④ What答:① 55H,70H,70H,65H,72H ② 53H,6CH,6FH,77H③ 43H,6FH,6DH,70H,75H,74H,65H,72H ④ 57H,68H,61H,74H1.7求下列带符号十进制数的8位基2码补码。
PSW
PSW(状态字寄存器)
D7 D6 D5 D4 D3 D2 D1 D0
CY:进位标志(如果最高位有进位或者借位,则该位为1,否则为0.)
AC:辅助进位标志,又称半进位标志。
它指两个八位运算第四位是否有进位。
F0:有用户使用的一个状态标志位,可用软件使它置1或清零,也可由软件来测试它以控制程序的流向。
RS1,RS0 :四组工作寄存器区选择控制位,在汇编语言中这两位用来选择四组工作寄存器中的哪一组为当前工作寄存区。
OV:溢出标志位,反应带符号数的运算是否溢出,有溢出为1,否则为0.
P:奇偶标志位,假如运算结果又偶数个1,则P为0,否则P为1.。
微机原理与接口技术习题答案2
第2章 8086 CPU 结构与功能1. 微处理器内部结构由哪几部分组成阐述各部分的主要功能。
解:微处理器内部结构由四部分组成:(1)算术逻辑运算单元ALU :完成所有的运算操作;(2)工作寄存器:暂存寻址信息和计算过程中的中间结果;(3)控制器:完成指令的读入、寄存和译码,并产生控制信号序列使ALU 完成指定操作;(4)I/O 控制逻辑:处理I/O 操作。
2. 微处理器级总线有哪几类各类总线有什么作用解:微处理器级总线有三类:(1)数据总线:传送信息;(2)地址总线:传送地址码;(3)控制总线 传送控制信号。
3. 为什么地址总线是单向的,而数据总线是双向的解:地址码只能由CPU 生成。
而数据需要在CPU 和存储器之间传输。
4. 8086/8088微处理器内部有哪些寄存器其主要作用是什么解:8086CPU 内部有14个16位寄存器,其中8个通用寄存器(4数据寄存器AX 、BX 、CX 、DX ,4地址指针/变址寄存器SI 、DI 、SP 、BP ),4个段寄存器(CS 、DS 、ES 、SS ),2个控制寄存器(指令指针IP ,微处理器状态字PSW )。
应该注意的是:可以在指令中用作为地址指针的寄存器有:SI 、DI 、BP 和BX ;在微处理器状态字PSW 中,一共设定了9个标志位,其中6个标志位用于反映ALU 前一次操作的结果状态(CF ,PF ,AF ,ZF ,SF ,OF ),另3个标志位用于控制CPU 操作(DF ,IF ,TF )。
5. 如果某微处理器有20条地址总线和16条数据总线:(1)假定存储器地址空间与I/O 地址空间是分开的,则存储器地址空间有多大(2)数据总线上传送的有符号整数的范围有多大解:(1)存储器地址空间为:2021MB =(2)有符号数范围为: 15152~21--, 即 -32768~327676. 将十六进制数62A0H 与下列各数相加,求出其结果及标志位CF 、AF 、SF 、ZF 、OF 和PF的值:(1)1234H;(2)4321H;(3)CFA0H;(4)9D60H解:(1)74D4H CF=0 AF=0 SF=0 ZF=0 OF=0 PF=1(2)A5C1H CF=0 AF=0 SF=1 ZF=0 OF=1 PF=0(3)3240H CF=1 AF=0 SF=0 ZF=0 OF=0 PF=0(4)0000H CF=1 AF=0 SF=0 ZF=1 OF=0 PF=17.从下列各数中减去4AE0H,求出其结果及标志位CF、AF、SF、ZF、OF和PF的值:(1)1234H;(2)5D90H;(3)9090H;(4)EA04H解:(1)C754H CF=1 AF=0 SF=1 ZF=0 OF=0 PF=0(2)12B0H CF=0 AF=0 SF=0 ZF=0 OF=0 PF=0(3)45B0H CF=0 AF=0 SF=0 ZF=0 OF=1 PF=0(4)9F24H CF=0 AF=0 SF=1 ZF=0 OF=0 PF=19.写出下列存储器地址的段地址、偏移地址和物理地址:(1)2134:10A0;(2)1FA0:0A1F;(3)267A:B876解:物理地址=段地址*10H+偏移地址(1)段地址:2134H,偏移地址:10A0H,物理地址:223E0H(2)段地址:1FA0H,偏移地址:0A1FH,物理地址:2041FH(3)段地址:267AH,偏移地址:B876H,物理地址:32016H10.给定一个数据的有效地址为2359H,并且(DS)=490BH,求该数据的物理地址。
psw是什么
psw 是什么
psw 的定义
PSW 即程序状态字(也叫程序状态寄存器)Program Status Word,可用于OS 在管态(系统态)和目态(用户态)之间的转换。
程序状态寄存器PSW 是计算机系统的核心部件运算器的一部分,PSW 用来存放两类信息:一类是体现当前指令执行结果的各种状态信息,称
为状态标志,如有无借位进位(CY 位)、有无溢出(OF 位)、结果正负(SF 位)、结果是否为零(ZF 位)、奇偶标志位(PF 位)等;另一类是存放控制
信息,称为控制状态,如允许中断(IF 位),跟踪标志(TF 位),方向标志(DF)等。
有些机器中将PSW 称为标志寄存器FR(Flag Register)。
在8086/8088CPU 中,PSW 是一个16 位寄存器,用于寄存单签指令执行后的某些状态,即反映指令执行结果的一些特征信息。
在debug 程序
中,可以使用R 命令来查看PSW 的值,除了TF 没有显示之外,其它8 个标志的值显示方式如下:。
标志寄存器
标志寄存器标志寄存器(Flags Register,FR)又称程序状态字(Program Status Word,PSW)。
这是一个存放条件标志、控制标志寄存器,主要用于反映处理器的状态和运算结果的某些特征及控制指令的执行。
各标志在标志寄存器中的位置:各标志在标志寄存器中的位置条件标志:CF(Carry Flag)进位标志:用于反映运算是否产生进位或借位。
如果运算结果的最高位产生一个进位或借位,则CF置1,否则置0。
运算结果的最高位包括字操作的第15位和字节操作的第7位。
移位指令也会将操作数的最高位或最低位移入CF。
PF(Parity Flag)奇偶标志:用于反映运算结果低8位中“1”的个数。
“1”的个数为偶数,则PF置1,否则置0。
AF(Auxiliary Carry Flag)辅助进位标志:在字节操作时低半字节向高半字节进位或借位,字操作时低字节向高字节进位或借位,AF置1,否则置0。
ZF(Zero Flag)零标志:用于判断结果是否为0。
运算结果0,ZF置1,否则置0。
SF(Sign Flag)符号标志:用于反映运算结果的符号,运算结果为负,SF置1,否则置0。
因为有符号数采用补码的形式表示,所以SF与运算结果的最高位相同。
OF(Overflow Flag)溢出标志:反映有符号数加减运算是否溢出。
如果运算结果超过了8位或者16位有符号数的表示范围,则OF置1,否则置0。
控制标志:TF(Trap Flag)陷阱标志:当TF被设置位1时,CPU进入单步模式,所谓单步模式就是CPU在每执行一步指令后都产生一个单步中断。
主要用于程序的调试。
8086/8088中没有专门用来置位和清零TF的命令,需要用其他办法。
IF(Interrupt Flag)中断标志:决定CPU是否响应外部可屏蔽中断请求。
IF为1时,CPU允许响应外部的可屏蔽中断请求。
DF(Direction Flag)方向标志:决定串操作指令执行时有关指针寄存器调整方向。
单片机原理与应用及C51程序设计(第三版)(1、2、3、4、7章课后习题答案)
第一章:1. 给出下列有符号数的原码、反码和补码(假设计算机字长为8位)。
+45 -89 -6 +112答:【+45】原=00101101,【+45】反=00101101,【+45】补=00101101【-89】原=11011001,【-89】反=10100110,【-89】补=10100111【-6】原=10000110,【-6】反=11111001,【-6】补=11111010【+112】原=01110000,【+112】反=01110000,【+112】补=011100002. 指明下列字符在计算机内部的表示形式。
AsENdfJFmdsv120答:41H 73H 45H 4EH 64H 66H 4AH 46H 6DH 64H 73H 76H 31H 32H 30H3.何谓微型计算机硬件?它由哪几部分组成?并简述各部分的作用。
答:微型计算机硬件由中央处理器、存储器、输入/输出设备和系统总线等组成,中央处理器由运算器和控制器组成,是微型计算机运算和控制中心。
存储器是用来存放程序和数据的记忆装置。
输人设备是向计算机输人原始数据和程序的装置。
输出设备是计算机向外界输出信息的装置。
I/O接口电路是外部设备和微型机之间传送信息的部件。
总线是连接多个设备或功能部件的一簇公共信号线,它是计算机各组成部件之间信息交换的通道。
微型计算机的各大功能部件通过总线相连。
4.简述8086CPU的内部结构。
答:8086微处理器的内部分为两个部分:执行单元(EU)和总线接口单元(BIU)。
执行部件由运算器(ALU)、通用寄存器、标志寄存器和EU控制系统等组成。
EU从BIU的指令队列中获得指令,然后执行该指令,完成指今所规定的操作。
总线接口部件BIU由段寄存器、指令指针寄存器、地址形成逻辑、总线控制逻辑和指令队列等组成。
总线接口部件负责从内部存储器的指定区域中取出指令送到指令队列中去排队。
5.何谓总线?总线按功能可分为哪几种?答:总线是连接多个设备或功能部件的一簇公共信号线,它是计算机各组成部件之间信息交换的通道。
汇编指令-状态寄存器、cmp、test、jz等指令详细说明
汇编指令-状态寄存器、cmp、test、jz等指令详细说明⼀、状态寄存器⾸先看看:状态寄存器(即标志寄存器)PSW(Program Status Word)程序状态字(即标志)寄存器,是⼀个16位寄存器,由条件码标志(flag)和控制标志构成,如下所⽰:条件码:①OF(Overflow Flag)溢出标志,溢出时为1,否则置0.标明⼀个溢出了的计算,如:结构和⽬标不匹配。
②SF(Sign Flag)符号标志,结果为负时置1,否则置0。
③ZF(Zero Flag)零标志,运算结果为0时置1,否则置0。
④CF(Carry Flag)进位标志,进位时置1,否则置0.注意:Carry标志中存放计算后最右的位。
⑤AF(Auxiliary carry Flag)辅助进位标志,记录运算时第3位(半个字节)产⽣的进位置。
有进位时1,否则置0。
⑥PF(Parity Flag)奇偶标志.结果操作数中1的个数为偶数时置1,否则置0。
控制标志位:⑦DF(Direction Flag)⽅向标志,在串处理指令中控制信息的⽅向。
⑧IF(Interrupt Flag)中断标志。
⑨TF(Trap Flag)陷井标志。
test和cmp指令运⾏后都会设置标志位,为举例⽅便说⼀下jnz和jz测试条件JZ ZF=1JNZ ZF=0即Jz=jump if zero (结果为0则设置ZF零标志为1,跳转)Jnz=jump if not zero⼆、test指令和cmp指令好,接着来看test和cmp1、test指令test属于逻辑运算指令功能:执⾏BIT与BIT之间的逻辑运算测试(两操作数作与运算,仅修改标志位,不回送结果)。
Test对两个参数(⽬标,源)执⾏AND逻辑操作,并根据结果设置标志寄存器,结果本⾝不会保存。
EST AX, BX 与 AND AX, BX 命令有相同效果语法:TEST r/m,r/m/data影响标志:C,O,P,Z,S(其中C与O两个标志会被设为0)运⽤举例:1.Test⽤来测试⼀个位,例如寄存器:test eax, 100b; b后缀意为⼆进制jnz ******; 如果eax右数第三个位为1,jnz将会跳转jnz跳转的条件⾮0,即ZF=0,ZF=0意味着零标志没被置位,即逻辑与结果为1。
微机原理与接口技术课后习题参考答案
微机原理与接口技术》李华贵主编课后习题参考答案第1章(1.6 习题)1.简述名词的概念:微处理器、微型计算机、微型计算机系统。
答:(1)微处理器:微处理器(Microprocessor)简称或MP,或CPU。
CPU是采用大规模和超大规模集成电路技术将算术逻辑部件ALU (Arithmetic Logic Unit )、控制部件CU (Co ntrol Un it )和寄存器组R (Registers)等三个基本部分以及内部总线集成在一块半导体芯片上构成的电子器件。
(2)微型计算机:微型计算机(Microcomputer )是指以微处理器为核心,配上由大规模集成电路制作的存储器、输入/输出接口电路及系统总线等所组成的计算机,简称微机。
(3)微型计算机系统:微型计算机系统由硬件与软件两大部分组成,分别称为硬件(Hardware)系统与软件(Software)系统。
其中,硬件(Hardware)系统由CPU、内存储器、各类I/O接口、相应的I/O设备以及连接各部件的地址总线、数据总线、控制总线等组成。
软件(Software)系统:计算机软件(Software)是指为运行、维护、管理、应用计算机所编制的程序及程序运行所需要的数据文档资料的总和。
一般把软件划分为系统软件和应用软件。
其中系统软件为计算机使用提供最基本的功能,但是并不针对某一特定应用领域。
而应用软件则恰好相反,不同的应用软件根据用户和所服务的领域提供不同的功能。
2.简述名词的概念:指令寄存器、地址寄存器、标志寄存器。
答:(1)指令寄存器:指令寄存器(Instruction Register,IR)用来保存计算机当前正在执行或即将执行的指令。
当一条指令被执行时,首先,CPU从内存取出指令的操作码,并存入IR中,以便指令译码器进行译码分析。
(2)地址寄存器:地址寄存器(Address Register,AR)被动地接受IP传送给它的地址值(二进制地址),AR的作用是保持IP送来的地址,并且以并行方式连接输出到CPU的地址引脚上,以便CPU访问指定的内存单元。
汇编语言复习提纲
2010数软班汇编语言程序设计复习提纲一、单项选择题1.指令指针寄存器是()。
A.BPB.SPC.IPD.PSW2. DAL DB 67HNUM EQU 80H则执行AND DAL,NUM语句后DAL中的内容是()。
A. E7HB. 80HC. 67HD. 03.与指令MOV AX,NOT 0F0H等效的汇编语言指令是()。
A. MOV AX,0FHB. MOV AX,0FF0FHC. MOV AX,000FHD. MOV AX,0F0H4.一个有16个字的数据区,它的起始地址是70A0H:DDF6H,则这个数据区最末一个字单元的物理地址是()。
A.7E806HB.7E814HC.7E815HD.7E80BHB5.可用作基址变址寻址或寄存器间接寻址的寄存器是()。
A.AX,BX,CX,DXB.DS,ES,CS,SSC.SP,BP,IP,BXD.SI,DI,BP,BXD6.在串操作指令中,下列描述中不正确的是()。
A.REP MOVSBB.REP STOSBC.REPE CMPSBD.REP LODSBD7. ORG 0030HDA1 DB 0 , ‘0’, 30H偏移地址为0030H字存储单元的内容是()。
A.3000HB.00HC.0030HD.3030HA8.编写分支程序,在进行条件判断前,可用指令构成条件,其中不能形成条件的指令是()。
A. CMPB.SUBC.ANDD.MOVD9.将汇编语言源程序翻译成机器码程序的程序是()。
A.编译程序B.汇编程序C.解释程序D.目标程序B10.设DS=1E4AH,偏移地址为0056H,该字节的物理地址为()。
A. 1E4A6HB. 1E456HC. 1E556HD. 1E4F6HD11.当程序顺序执行时,每取一条指令语句,IP指针增加的值是()A.由指令长度决定的字节数B.1C.2D.3A12.若AX=349DH, CX=0FH。
则执行指令AND AX,CX后,AX的值是()。
8086标志寄存器
8086标志寄存器CPU内部的寄存器中,有⼀种特殊的寄存器(对于不同的机器,个数和结构都有可能不同)具有以下三个功能:⽤来存储某些相关指令的执⾏结果⽤来为CPU执⾏相关的指令提供⾏为依据⽤来控制CPU的相关⼯作⽅式这种特殊的寄存器在8086CPU中称为标志寄存器。
8086的标志寄存器有16位,其中存储的信息通常被称为程序状态字(PSW)。
标志寄存器与其他寄存器不⼀样,其他寄存器是⽤来放数据的,都是整个寄存器具有⼀个含义,⽽标志寄存器是按位起作⽤的。
8086中的标志寄存器的结构如下图所⽰:其中1、3、4、12、13、14、15位在8086中没有使⽤。
另外对于有确切含义的每⼀位,我们称为标志位ZF标志标志寄存器的第六位是ZF,零标志位。
他是记录相关指令执⾏后,其结果是否位零。
如果为零,那么zf=1,如果不为零,那么zf=0⽐如指令:mov ax, 1sub ax, 1执⾏后,ax的结果为0,所以zf=1再⽐如:mov ax, 2sub ax, 1执⾏后,ax的结果不为0,所以zf=0在这⾥,有⼀点需要注意:在8086的指令集中,有的指令的执⾏是影响标志位的,⽐如add、sub、mul、div、inc、or、and等,它们⼤都是运算指令(进⾏逻辑或算数运算);有的指令的执⾏对标志寄存器没有影响,⽐如mov、push、pop等,它们⼤都是传送指令。
PF标志标志寄存器的第⼆位是PF,奇偶标志位。
它记录相关指令执⾏后,其结果的所有bit位中1的个数是否位偶数。
如果是偶数,pf=1,如果位奇数,pf=0⽐如指令:mov al, 1add al, 10执⾏后,al为00001011B,其中有3个1,所以pf=0再⽐如:mov al, 1or al, 2执⾏后结果为00000011B,其中有2个1,所以pf=1SF标志标志寄存器的第七位是SF,符号标志位。
它记录相关指令执⾏后,其结果是否为负。
如果为负,sf=1,如果⾮负,sf=0这⾥要明确⼀点,在计算机中,通常⽤补码来表⽰有符号的数据,计算机中的⼀个数据既可以看作有符号数,也可以看作⽆符号数。
标志寄存器解析
标志寄存器CPU内部的寄存器中,有一种特殊的寄存器(对于不同的处理机,个数和结构都可能不同)具有三种作用:1)用来存储相关指令的某些执行结果;2)用来为CPU执行相关指令提供行为依据;3)用来控制CPU的相关工作方式。
这种特殊的寄存器在8086CPU中,被称为标志寄存器。
8086CPU的标志寄存器有16位,其中存储的信息通常被称为程序状态字(PSW)。
简称flag。
flag和其他寄存器不一样,其他寄存器是用来存放数据的,都是整个寄存器具有一个含义。
而flag寄存器是按位起作用的,也就是说,它的每一位都有专门的含义,记录特定的信息。
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0flag的1、3、5、12、13、14、15位在8086CPU中没有使用,不具有任何含义,而其余位都具有特殊的含义。
ZF标志flag的第6位是ZF,零标志位。
它记录相关指令执行后,其结果是否为0。
如果结果为0,那么ZF=1,如果结果不为0,那么ZF=0。
mov ax,1sub ax,1执行后,结果为0,则ZF=1,表示“结果是0”。
mov ax,2sub ax,1执行后,结果不为0,则ZF=0,表示“结果不是0”。
在计算机中0表示逻辑假,表示否定,1表示逻辑真,表示肯定。
注意,在8086CPU的指令集中,有的指令的执行是影响标志寄存器的,比如:add、sub、mul、div、inc、or、and等,它们大都是运算指令(进行逻辑或自述运算);有的指令的执行对标志寄存器没有影响,比如:mov、push、pop等,它们大都是传送指令。
我们在使用一条指令的时候,要注意这条指令的全部功能,其中包括,执行结果对标记寄存器的哪些标志位造成影响。
PF标志flag的第2位是PF,奇偶标志位。
它记录相关指令执行后,其结果的所有二进制位中1的个数是否为偶数。
如果1的个数为偶数,PF=1,如果为奇数,那么PF=0。
比如:mov al,1add al,10执行后,结果为00001011B,其中有3(奇数)个1,则PF=0。
psw标志寄存器
一、标志寄存器PSW
标志寄存器PSW(程序状态字寄存器PSW)
标志寄存器PSW是一个16为的寄存器。
它反映了CPU运算的状态特征并且存放某些控制标志。
8086使用了16位中的9位,包括6个状态标志位和3个控制标志位。
CF(进位标志位):当执行一个加法(减法)运算时,最高位产生进位(或借位)时,CF 为1,否则为0。
ZF零标志位:若当前的运算结果为零,则ZF为1,否则为0。
SF符号标志位:该标志位与运算结果的最高位相同。
即运算结果为负,则SF为1,否则为0。
OF溢出标志位:若运算结果超出机器能够表示的范围称为溢出,此时OF为1,否则为0。
判断是否溢出的方法是:进行二进制运算时,最高位的进位值与次高位的进位值进行异或运算,若运算结果为1则表示溢出OF=1,否则OF=0
PF奇偶标志:当运算结果的最低16位中含1的个数为偶数则PF=1否则PF=0
AF辅助进位标志:一个加法(减法)运算结果的低4位向高4位有进位(或借位)时则AF=1否则AF=0
另外还有三个控制标志位用来控制CPU的操作,可以由程序进行置位和复位。
TF跟踪标志:该标志位为方面程序调试而设置。
若TF=1,8086/8088CPU处于单步工作方式,即在每条指令执行结束后,产生中断。
IF中断标志位:该标志位用来控制CPU是否响应可屏蔽中断。
若IF=1则允许中断,否则禁止中断。
DF方向标志:该标志位用来控制串处理指令的处理方向。
若DF=1则串处理过程中地址自动递减,否则自动递增。
OD里能查看到除IF标志外的8个标志位。
合工大微机原理周国祥第二章思考题答案
1.8086/8088 CPU由哪两部分组成?它们的主要功能各是什么?它们之间是如何协调工作的?解:8086的内部结构由两部分组成:总线接口部件BIU,负责与存储器、I/O端口传送数据执行部件EU, 负责指令的执行。
协调工作过程:总线接口部件和执行部件并不是同步工作的,它们按以下流水线技术原则来协调管理:①每当 8086 的指令队列中有两个空字节,或者 8088 的指令队列中有一个空字节时,总线接口部件就会自动把指令取到指令队列中。
②每当执行部件准备执行一条指令时,它会从总线接口部件的指令队列前部取出指令的代码,然后用几个时钟周期去执行指令。
在执行指令的过程中,如果必须访问存储器或者输入/输出设备,那么,执行部件就会请求总线接口部件进入总线周期,完成访问内存或者输入/输出端口的操作;如果此时总线接口部件正好处于空闲状态,那么,会立即响应执行部件的总线请求。
但有时会遇到这样的情况,执行部件请求总线接口部件访问总线时,总线接口部件正在将某个指令字节取到指令队列中,此时总线接口部件将首先完成这个取指令的操作,然后再去响应执行部件发出的访问总线的请求。
③当指令队列已满,而且执行部件又没有总线访问请求时,总线接口部件便进入空闲状态。
④在执行转移指令、调用指令和返回指令时,由于程序执行的顺序发生了改变,不再是顺序执行下面一条指令,这时,指令队列中已经按顺序装入的字节就没用了。
遇到这种情况,指令队列中的原有内容将被自动消除,总线接口部件会按转移位置往指令队列装入另一个程序段中的指令。
2.8086/8088 CPU中有哪些寄存器?各有什么用途?标志寄存器F有哪些标志位?各在什么情况下置位?解答:标志寄存器F的标志位:①控制标志:OF、DF、IF、TF;②状态标志:SF、ZF、AF、PF、CF。
标志寄存器F的各标志位置位情况:· CF:进位标志位。
做加法时出现进位或做减法时出现借位,该标志位置1;否则清0。
汇编语言标志位(CF)及一些常用指令
汇编语言标志位(CF)及一些常用指令英文翻译:carry 进位 flag标志NV: no overflow OV: overflowUP: up DN:downDI: disable interrupt EI: enable interruptPL: plus NG: negativeNZ: no zero ZR: zeroNA: no assistant carry AC: assistant carryPO: parity odd PE: parity even 奇偶校验NC: no carry CY: carry汇编标志位:标志名标志 1 标志 0 OF (溢出标志) OV NVDF (方向标志) UP DNIF (中断标志) DI EISF (符号标志位) PL NGZF (零标志) NZ ZRAF (辅助进位标志位) NA ACPF (奇偶标志) PO PECF (进位标志) NC CYOF 溢出(是/否) OV OVerflow NV Not oVerflowDF 方向(减量/增量) DN DowN UP UPIF 中断(允许/关闭) EI Enable Interrupt DI Disable InterruptSF 符号(负/正) NG NeGative PL PLusZF 零(是/否) ZR ZeRo NZ Not ZeroAF 辅助进位(是/否) AC Auxiliary Carry NA Not AuxiliaryPF 奇偶(是/否) PE Parity Even PO Parity OddCF 进位(是/否) CY CarrY NC Not Carry英文解释:NV: no overflow OV: overflowUP: up DN:downDI: disable interrupt EI: enable interruptPL: plus NG: negativeNZ: no zero ZR: zeroNA: no assistant carry AC: assistant carryPO: parity odd PE: parity evenNC: no carry CY: carry先熟悉一下FLAGS标志位:OV、NV即溢出标志位OF=1或0,表示运算结果有无溢出。
PSW状态字百度百科
PSW即程序状态字(有些教材也叫程序状态寄存器),Program Status Word
程序状态寄存器PSW是计算机系统的核心部件——控制器的一部分,PSW用来存放两类信息:
一类是体现当前指令执行结果的各种状态信息,称为状态标志,
如有无进位(CF位),有无溢出(OF位),
NV UP DI PL NZ NA PO NC依次表示OF DF IF SF ZF AF PF CF都为0.
PSW各位的定义如下:
Cy(PSW.7):即PSW的D7位,进位、借位标志。 进位、借位CY=1;否则CY=0.
AC(PSW.6):即PSW的D6位,辅助进位、借位标志。 当D3向D4有借位或进位时,AC=1;否则AC=0.
,即反映指令执行结果的一些特征信息。在debug程序中,可以使用R命令来查看PSW的值,
除了TF没有显示之外,其它8个标志的值显示方式如下:
标志名
设置 nv(清除) ov(溢出)
方向 dn(减) up(增)
中断Байду номын сангаас ei(启用) di(禁用)
F0(PSW.5及PSW.1):即PSW的D5位,用户标志位;
RS1及RS0(PSW.4及PSW.3):即PSW的D4、D3位, 寄存器组选择控制位;
OV(PSW.2):溢出标志。有溢出OV=1,否则OV=0;
F1(PSW·1):保留位,无定义;
P(PSW·0):奇偶校验标志位,由硬件置位或清0;存在ACC中的运算结果有奇数个1时P=1,否则P=0。
结果正负(SF位),结果是否为零(ZF位),
奇偶标志位(PF位)等;
另一类是存放控制信息,称为控制状态,
标志位
--标志位简介:标志寄存器,又称程序状态寄存器(它的内容是ProgramStatusWord,PSW).这是一个存放条件码标志,控制标志和系统标志的寄存器.6个状态标志位CF—进位标志,加法时的最高位(D7或D15)产生进位或减法时最高位出现借位,则CF=1,否则CF=0;AF—辅助进位标志,供BCD码使用。
当D3位出现进位或借位时AF=1,否则AF=0;OF—溢出标志,带符号数进行算术运算时,其结果超出了8位或16位的表示范围,产生溢出,则OF=1,否则OF=0;ZF—零标志,运算结果各位都为零,则ZF=1,否则ZF=0;SF—符号标志,运算结果为负数时,即运算结果的最高位为1,则SF=1,否则SF=0;PF—奇偶标志,反映操作结果中“1”的个数的情况,若有偶数个“1”,则PF=1,否则PF=0。
3个控制标志位DF—方向标志,用来控制数据串操作指令的步进方向;当设置DF=1时,将以递减顺序对数据串中的数据进行处理。
当设置DF=0时,递增。
IF—中断允许标志,当设置IF=1,开中断,CPU可响应可屏蔽中断请求;当设置IF=0时,关中断,CPU不响应可屏蔽中断请求。
TF—陷阱标志,为程序调试而设的。
当设置TF=1,CPU处于单步执行指令的方式;当设置TF=0时,CPU正常执行程序。
详解:1、进位标志CF(CarryFlag)当运算结果的最高有效位有进位(加法)或借位(减法)时,进位标志置1,即CF=1;否则CF=0。
49H+6DH=B6H,没有进位:CF=0BBH+6AH=(1)25H,有进位:CF=12、零标志ZF(ZeroFlag)若运算结果为0,则ZF=1;否则ZF=049H+6DH=B6H,结果不是零:ZF=075H+8BH=(1)00H,结果是零:ZF=13、符号标志SF(SignFlag)运算结果最高位为1,则SF=1;否则SF=049H+6DH=B6H=10110110B,SF=14、奇偶标志PF(ParityFlag)当运算结果最低字节中“1”的个数为零或偶数时,PF=1;否则PF=03AH+7CH=B6H=10110110B结果中有5个1,是奇数:PF=05、溢出标志OF(OverflowFlag)若算术运算的结果有溢出,则OF=1;否则OF=049H+6DH=B6H,产生溢出:OF=175H+8BH=(1)26H,没有溢出:OF=0什么是溢出?处理器内部以补码表示有符号数8位表达的整数范围是:+127~-12816位表达的范围是:+32767~-32768如果运算结果超出这个范围,就产生了溢出有溢出,说明有符号数的运算结果不正确49H+6DH=B6H,就是73+109=182,已经超出-128~+127范围,产生溢出,故OF=1;另一方面,补码B6H表达真值是-74,显然运算结果也不正确溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出范围,运算结果已经不正确。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
例题1: 例题 :
8位二进制加法,判断CF和OF 2H+7FH
看作无符号数 看作有符号数 2 + 1 27 1 29
00000010 + 01111111 10000001 CF=0,OF=1
2 + 1 27 1 29
不溢出
溢 出
例题2: 例题 :
8位二进制加法,判断CF和OF 86H+0F5H
CF和OF的判断方法: 和 的判断方法 的判断方法:
请看例题1 请看例题
1、加法: 、加法: CF:十进制角度。作为 位无符号数,若加法的结果 位无符号数, :十进制角度。作为n位无符号数 >2n-1,则CF=1,否则 , ,否则CF=0。 = 。 二进制角度。若结果的最高位向前有进位, 二进制角度。若结果的最高位向前有进位,则 CF=1,否则 =0。 = ,否则CF= 。 OF:十进制角度。作为 位有符号数,若加法的结果 位有符号数, :十进制角度。作为n位有符号数 不在-2 范围之内, 不在 n-1~2n-1-1范围之内,则OF=1,否则 范围之内 = ,否则OF=0. 二进制角度。若两个数同号, 二进制角度。若两个数同号,而相加结果与之 异号,则说明溢出, = ,否则OF= 异号,则说明溢出,OF=1,否则 =0.
课后小结:
1、进位标志CF和溢出标志 是两个意义 、进位标志 和溢出标志 和溢出标志OF是两个意义 不同的标志 2、进位标志表示无符号数运算结果是否 、 超出范围,运算结果仍然正确; 超出范围,运算结果仍然正确; 3、溢出标志表示有符号数运算结果是否 、 超出范围,运算结果已经不正确。 超出范围,运算结果已经不正确。
看作无符号数 看作有符号数 -1 2 2 + -1 1 -1 3 3
10000110 + 11110101 1↖ 0 1 1 1 1 0 1 1 CF=1,OF=1
134 + 24 5 3 79
溢 出
溢 出
CF和OF的判断方法: 和 的判断方法 的判断方法:
请看例题3 请看例题
1、减法: 、减法: CF:十进制角度。作为 位无符号数,若减数大于被 位无符号数, :十进制角度。作为n位无符号数 减数, 减数,则CF=1,否则 =0。 ,否则CF= 。 二进制角度。若减法时最高位向前有借位, 二进制角度。若减法时最高位向前有借位,则 CF=1,否则 =0。 = ,否则CF= 。 OF:十进制角度。作为 位有符号数,若减法的结果 位有符号数, :十进制角度。作为n位有符号数 不在-2 范围之内, 不在 n-1~2n-1-1范围之内,则OF=1,否则 范围之内 = ,否则OF=0. 二进制角度。若两个数异号, 二进制角度。若两个数异号,而减法的结果与 减数符号相同,则说明溢出, = ,否则OF= 减数符号相同,则说明溢出,OF=1,否则 =0.
例题3: 例题 :
8位二进制减法,判断CF和OF 81H—3H
看作无符号数 看作有符号数 -127 — 3 -130
10000001 — 00000011 01111110 CF=0,OF=1
129 — 3 126
不溢出
溢 出
例题4: 例题 :
8位二进制减法,判断CF和OF 7FH-0FDH
看作无符号数 看作有符号数 127 — -3 130
教具及主要教学手段: 多媒体讲述法
教学内容及过程:
8086CPU的标志寄存器FLAGS中,含有9个标志, 其中包括6个状态标志和3个控制标志,每个 标志占1位,这些标志用来表示CPU当前的操 作方式和状态信息
15 12 11
OF
10
DF
9
IF
8
TF
7
SF
6
ZF
5
4
AF
3
2
PF
1
0
CF
进位标志位CF( 进位标志位 (Carry Flag) )
作业:
给出下列8位数运算后,CF、OF的值 80H+80H 0F9H+02H 80H-21H 35H-0A5H
完
溢出标志位OF( 溢出标志位 (Overflow Flag) )
若算术运算的结果有溢出, 若算术运算的结果有溢出,则 OF=1;否则OF= OF=1;否则OF=0. 表示有符号数溢出, 表示有符号数溢出,即运算结果 超出了有符号数的表示范围。 超出了有符号数的表示范围。n 位二进制数表示的有符号数范围 为-2n-1~2n-1-1。 。
01111111 — 11111101 10000010 CF=1,OF=1
127 — 253 130
溢 出
溢 出
练习: 练习:
8位二进制加、减法,判断CF和OF 3H+0FEH
00000011 + 11111110 1↖ 0 0 0 0 0 0 0 1 CF=1,OF=0
2-3
00000010 ﹣ 00000011 1↖ 1 1 1 1 1 1 1 1 CF=1,OF=0 ,
当运算结果的最高位发生进位(加法) 当运算结果的最高位发生进位(加法) 或借位(减法) 进位标志置1, 或借位(减法)时,进位标志置1, 即CF=1;否则 ;否则CF=0。 。 表示无符号数溢出, 表示无符号数溢出,即运算结果超出 了无符号数的表示范围。 位二进制 了无符号数的表示范围。n位二进制 数表示的无符号数范围为0 数表示的无符号数范围为 ~2n-1。 。
标志寄存器(FLAGS)中CF、OF的判断 中 、 的判断 标志寄存器
主讲人: 主讲人:杨慧丽
教学目的:
1、进一步熟悉FLAGS中的9个标志位; 2、理解溢出的两种不同含义; 3、熟练掌握加、减法及逻辑指令中对CF、 OF的判断; 4、了解乘法中对CF、OF的判断;
重点及难点:
在加、减、乘法运算中,对CF、OF的判断 从十进度角度理解溢出的两种不同含义