- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第三章 习题及答案
(★难度,其中难度分别为容易、一般、较难、困难,分别对应数字1、2、3、4)
1 .简述8086/8088CPU 中BIU 和EU 的作用,并说明其并行工作过程。(难度3)
答: (1) BIU 的作用:计算20 位的物理地址,并负责完成CPU 与存储器或I/O 端
口之间的数据传送。
(2) EU 的作用:执行指令,并为BIU 提供所需的有效地址。
(3) 并行工作过程:当EU 从指令队列中取出指令执行时,BIU 将从内存中取出指
令补充到指令 队列中。这样就实现了取指和执行指令的并行工作。
2 .8086/8088CPU 内部有哪些寄存器?其主要作用是什么? (难度1)
答:8086/8088CPU 内部共有14 个寄存器,可分为4 类:数据寄存器4 个,地址寄
存器4 个,段寄存器4 个和控制寄存器2 个。其主要作用是:
(1) 数据寄存器:一般用来存放数据,但它们各自都有自己的特定用途。
AX(Accumulator)称为累加器。用该寄存器存放运算结果可使指令简化,提高指令的
执行速度。此外,所有的I/O 指令都使用该寄存器与外设端口交换信息。
BX(Base)称为基址寄存器。用来存放操作数在内存中数据段内的偏移地址,
CX(Counter)称为计数器。在设计循环程序时使用该寄存器存放循环次数,可使程序
指令简化, 有利于提高程序的运行速度。
DX(Data)称为数据寄存器。在寄存器间接寻址的I/O 指令中存放I/O 端口地址;
在做双字长乘除法运算时,DX 与AX 一起存放一个双字长操作数,其中DX 存放高16
位数。
(2) 地址寄存器:一般用来存放段内的偏移地址。
SP(Stack Pointer)称为堆栈指针寄存器。在使用堆栈操作指令(PUSH 或POP)对堆栈进
行操作时,每执行一次进栈或出栈操作,系统会自动将SP 的内容减2 或加2 ,以使其始
终指向栈顶。
BP(Base Pointer)称为基址寄存器。作为通用寄存器,它可以用来存放数据,但更经
常更重要的 用途是存放操作数在堆栈段内的偏移地址。
SI(Source Index)称为源变址寄存器。SI 存放源串在数据段内的偏移地址。
DI(Destination Index)称为目的变址寄存器。DI 存放目的串在附加数据段内的偏移地
址。
(3) 段寄存器:用于存放段地址
CS(Code Segment)称为代码段寄存器,用来存储程序当前使用的代码段的段地址。
CS 的内容 左移4 位再加上指令指针寄存器IP 的内容就是下一条要读取的指令在存储器
中的物理地址。
DS(Data Segment)称为数据段寄存器,用来存放程序当前使用的数据段的段地址。
DS 的内容左 移4 位再加上按指令中存储器寻址方式给出的偏移地址即得到对数据段指
定单元进行读写的物理地址。
SS(Stack Segment)称为堆栈段寄存器,用来存放程序当前所使用的堆栈段的段地址。
堆栈是存 储器中开辟的按“先进后出”原则组织的一个特殊存储区,主要用于调用子
程序或执行中断服务程 序时保护断点和现场。
ES(Extra Segment)称为附加数据段寄存器,用来存放程序当前使用的附加数据段的
段地址。附 加数据段用来存放字符串操作时的目的字符串。
(4) 控制寄存器
IP(Instmcdon Pointer)称为指令指针寄存器,用来存放下一条要读取的指令在代码段
内的偏移地 址。用户程序不能直接访问IP 。
FLAGS 称为标志寄存器,它是一个16 位的寄存器,但只用了其中9 位,这9 位包
括(个状态标 志位和3 个控制标志位。它用来反映算术运算和逻辑运算结果的一些特征,
或用来控制CPU 的某种操作。
3 .8086/8088CPU 中有哪些寄存器可用来指示操作数在存储器中某段内的偏移地
址? (难度4)
答:可用来指示段内偏移地址的寄存器共有6 个:IP、SP、BP 、BX 、SI、DI
4 .8086/8088CPU 中标志寄存器FLAGS 有哪些标志位? 它们的含义和作用如何? (难
度1)
答:标志寄存器中的标志共有9 个,分为两类:状态标志6 个和控制标志3
文档评论(0)