欢迎来到天天文库
浏览记录
ID:12388435
大小:87.00 KB
页数:11页
时间:2018-07-16
《微机原理习题答案3》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、《微型计算机原理》习题3(P117)参考答案(部分题号与教材有错位,请注意)3.1为什么要研究8086/8088微处理器及其系统?这比直接研究32位微处理器及其系统有何优缺点?解:尽管8086/8088后续的80286、80386、80486以及Pentium系列CPU结构和功能已发生很大变化,但从基本概念与结构以及指令格式上来讲,他们仍然是经典的8086/8088CPU的延续与提升。3.28086CPU有多少根数据线和地址线?它能寻址多少内存地址单元和I/O端口?8088CPU又有多少根数据线和地址线?为什么要设计8088CPU?解:8086CPU有16根数据线和20根地址线
2、,可寻址1MB存储单元和64KB的I/O端口。8088CPU有16位内部数据线和8条外部数据总线,20根地址线。8088CPU是8086CPU的向下兼容版,这样设计主要为了与INTEL原有的8位外围接口芯片直接兼容。3.38086CPU内部按功能可分为哪两大部分?他们各自的主要功能是什么?解:从功能上讲,8086可分为两个部分,即总线接口单元(businterfaceunit,BIU)和执行单元(executionunit,EU)。总线接口单元(BIU)的功能是负责CPU与存储器或I/O设备之间的数据传送。EU的功能只是负责执行指令;执行的指令从BIU的指令队列缓冲器中取得,执
3、行指令的结果或执行指令所需要的数据,都由EU向BIU发出请求,再由BIU经总线控制电路对存储器或外设存取。3.48086CPU内部的总线接口单元BIU由哪些功能部件组成?他们的基本操作原理是什么?解:BIU内有4个16位的段地址寄存器CS、DS、SS和ES,16位指令指针IP,6字节指令队列缓冲器,20位地址加法器和总线控制电路。基本操作原理是BIU要从内存取指令送到指令队列缓冲器;CPU执行指令时,总线接口单元要配合执行单元从指定的内存单元或者外设端口中取数据,将数据传送给执行单元,或者把执行单元的操作结果传送到指定的内存单元或外设端口中。3.5什么叫微处理器的并行操作方式?
4、为什么说8086CPU具有并行操作的功能?在什么情况下8086的执行单元EU才需要等待总线接口单元BIU提取指令?解:并行操作,就是CPU执行完1条指令后就可以立即执行下一条指令,而不需要像以往8位CPU那样重复的进行先取指令和后执行的指令串行操作。16位CPU的这种并行操作的特点,提高了总线的信息传输效率和整个系统的执行速度。只有当遇到转移指令、调用指令或返回指令时,或者当某一条指令在执行过程中,需要频繁访问内存以至于总线接口单元没有空闲从内存将指令提取到指令队列中时,才需要等待总线接口单元BIU提取指令。3.6逻辑地址和物理地址有什么区别?为什么8086微处理器要引入“段加
5、偏移”的技术思想?段加偏移的基本含义又是什么?试举例说明。解:逻辑地址由16位段地址和16位段内偏移量(又称有效地址)组成,程序中指令必须通过逻辑地址访问内存。物理地址是由20条地址线信号指示的内存地址,在电路中必须使用这20条物理的地址信号线访问内存。物理地址=段地址×16+有效地址。参考教材:⑴P54第3~11行⑵P56“2。段寄存器”的第1段⑶P70“3。3。5‘段加偏移’寻址机制允许重定位”11段加偏移的基本含义是:将段寄存器内容左移4位后与16位偏移地址相加。例:假设CS=FA00H,IP=0300H,这是物理地址为0FA300H。3.7在微处理器中设置指令队列缓冲器
6、有什么作用?8086与8088CPU中的指令队列有何区别?解:指令队列缓冲器在执行指令的同时,可以从内存中取下面一条或几条指令,取来的指令就依次暂放在指令队列中。区别:8086指令队列为6个字节,8088为4字节;8086指令队列只要空出2个,而8088只要空出1个指令字节时,BIU便自动执行取指操作,直到填满为止。3.88086CPU的基址寄存器BX和基址指针(或基址指针寄存器)BP有何区别?基址指针BP和堆栈指针SP在使用中有何区别?解:基址寄存器BX在查表指令XLAT中存放表的起始地址,而基址指针BP用来存放堆栈地址。指针寄存器SP和BP都用来指示存储位于当前堆栈段中的数
7、据所在的地址,但SP和BP在使用上有区别。入栈和出栈指令是由SP给出栈顶的偏移地址,故称为堆栈指针寄存器。而BP则是存放位于堆栈段中的一个数据区的基地址的偏移地址,故称为堆栈基址指针寄存器。3.9段地址和段起始地址相同吗?两者是什么关系?8086的段起始地址就是段基址吗?它是怎样获得的?解:不同。为了使8086/8088CPU能够寻址1MB内存空间,在其内部设计了一组16位的段寄存器,用这些段寄存器的内容作为段地址,再由段寄存器左移4位形成20位的段起始地址。8086的段起始地址就是段基址。
此文档下载收益归作者所有