- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机硬件 1.2.2 寄存器介绍 * 链接3 什么是溢出? 处理器内部以补码表示有符号数 8位表达的整数范围是:+127 ~ -128 16位表达的范围是:+32767 ~ -32768 如果运算结果超出这个范围,就产生了溢出 有溢出,说明有符号数的运算结果不正确 3AH+7CH=B6H,就是58+124=182, 已经超出-128~+127,产生溢出,故OF=1 补码B6H表达真值是-74,显然运算结果也不正确 什么是溢出? 溢出和进位的区别 溢出标志OF和进位标志CF是两个意义不同的标志 进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确 溢出标志表示有符号数运算结果是否超出范围,运算结果已经不正确 溢出与进位的区别 溢出和进位的对比 例1: 3AH+7CH=B6H 无符号数运算: 58+124=182 范围内,无进位 有符号数运算: 58+124=182 范围外,有溢出 例2:AAH+7CH=(1)26H 无符号数运算: 170+124=294 范围外,有进位 有符号数运算: -86+124=38 范围内,无溢出 溢出与进位的对比 溢出和进位的应用场合 应该利用哪个标志,则由程序员来决定。也就是说,如果将参加运算的操作数认为是无符号数,就应该关心进位;认为是有符号数,则要注意是否溢出 溢出与进位的应用场合 例1:3AH+7CH=B6H 例2:AAH+7CH=26H 例3:3AH-7CH=BEH 例4:AAH-7CH=2EH 溢出的判断 判断运算结果是否溢出有一个简单的规则: 当两个相同符号数相加,而运算结果的符号与加数、被加数的符号不同时,产生溢出; 当两个异号数相减,运算结果若与被减数符号不同,则产生溢出; 其它情况下,则不会产生溢出 溢出 溢出 溢出的判断 无溢出 无溢出 辅助进位标志AF(Auxiliary Carry Flag) 3AH+7CH=B6H,D3有进位:AF=1 运算时D3位(低半字节)有进位或借位时,AF=1;否则AF=0 这个标志主要由处理器内部使用,用于十进制算术运算调整指令中,用户一般不必关心 辅助进位标志AF(Auxiliary carry Flag) 方向标志DF(Direction Flag) 用于串操作指令中,控制地址的变化方向: 设置DF=0,存储器地址自动增加; 设置DF=1,存储器地址自动减少 CLD指令复位方向标志:DF=0 STD指令置位方向标志:DF=1 方向标志DF(Direction Flag) 中断允许标志IF(Interrupt-enable Flag) 控制可屏蔽中断是否可以被处理器响应: 设置IF=1,则允许中断; 设置IF=0,则禁止中断 CLI指令复位中断标志:IF=0 STI指令置位中断标志:IF=1 中断允许标志IF(Interrupt-enable Flag) 陷阱标志TF(Trap Flag) 用于控制处理器进入单步操作方式: 设置TF=0,处理器正常工作; 设置TF=1,处理器单步执行指令 单步执行指令——处理器在每条指令执行结束时,便产生一个编号为1的内部中断 这种内部中断称为单步中断 所以TF也称为单步标志 利用单步中断可对程序进行逐条指令的调试 这种逐条指令调试程序的方法就是单步调试 陷进标志TF(Trap Flag) 段寄存器 8086/8088有4个16位段寄存器: 代码段寄存器CS(Code Segment), 数据段寄存器DS(Data Segment), 堆栈段寄存器SS(Stack Segment) 附加数据段寄存器ES(Extra Segment) 为什么需要设置段寄存器?? 存储器寻址机制 8086: 20位地址信息,lMB字节,但内部只能进行16位运算,这就是说它能处理的地址信息仅16位。 为解决这一矛盾,把存储器划分为“段”,每个段的实际长度≤64KB。表示不同段的段地址,分别存放于四个段寄存器(CS、DS、SS、ES)中。 为什么必须对存储器分段管理?? 1.2.3存储器寻址机制 存储器是计算机存储信息的地方。掌握数据存储格式,以及存储器的分段管理对以后的汇编程序设计非常重要 你能区别寄存器、存储器(主存)、外存(包括硬盘、光盘、磁带等存储介质)吗? 寄存器、存储器和外存的区别 寄存器是微处理器(CPU)内部暂存数据的存储单元,以名称表示,例如:AX,BX..….等; 存储器也就是平时所说的主存,也叫内存,可直接与CPU进行数据交换。主存利用地址区别; 外存主要指用来长久保存数据的外部存储介质,常见的有硬盘、光盘、磁带、U盘等。外存的数据只能通过主存间接地与CPU交换数据; 程序及其数据可以长久存放在外存,在运行需要时才进入主存。 存储单元及其存储内容 每个存储单元都有一个编号;被
文档评论(0)