3683951205微型计算机原理复习资料_第1页
3683951205微型计算机原理复习资料_第2页
3683951205微型计算机原理复习资料_第3页
3683951205微型计算机原理复习资料_第4页
3683951205微型计算机原理复习资料_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、微性计算机原理习题解答习题11.1 冯诺依曼型计算机的设计方案有哪些特点?【解答】冯诺依曼型计算机的设计方案是“存储程序”和“程序控制”,有以下5方面特点:(1)用二进制数表示数据和指令;(2)指令和数据存储在内部存储器中,按顺序自动依次执行指令;(3)由运算器、控制器、存储器、输入设备和输出设备组成基本硬件系统;(4)由控制器来控制程序和数据的存取及程序的执行;(5)以运算器为核心。1.2 微处理器和微型计算机的发展经历了哪些阶段?各典型芯片具备哪些特点?【解答】经历了6代演变,各典型芯片的特点如表1-1所示。表1-1 微处理器的发展及典型芯片的特点发展时代类别典型芯片及性能特点第一代(19

2、711973年)4、8位低档微处理器intel 4004集成2300多个晶体管,主频108khz,寻址640byte,指令系统简单;intel 8008采用pmos工艺,集成3500晶体管,基本指令48条,主频500khz。 第二代(19741977年)8位中高档微处理器intel 8080采用nmos工艺,集成6000晶体管,主频2mhz,指令系统较完善,寻址能力增强,运算速度提高了一个数量级。第三代(19781984年)16位微处理器intel 8086采用hmos工艺,集成29000晶体管,主频5mhz/8mhz/10mhz ,寻址1mb。intel 80286集成度达到13.4万晶体管

3、,主频20mhz。第四代(19851992年)32位微处理器intel 80386集成27.5万个晶体管,主频33mhz,4gb物理寻址。有分段存储和分页存储部件,可管理64tb虚拟存储空间。intel 80486集成120万个晶体管,包含浮点运算部件和8kb的一级高速缓冲存储器cache。第五代(19931999年)超级32位微处理器intel pentium、pentium pro、pentium mmx、pentium ii、 pentium iii、pentium 4微处理器等,采用新式处理器结构,数据加密、视频压缩和对等网络等方面性能有较大幅度提高。第六代(2000年以后)64位微处

4、理器merced由intel公司与hp公司联手开发的merced采用全新的ia-64结构设计,是一种采用长指令字、指令预测、分支消除、推理装入和其他一些先进技术的全新结构微处理器。1.3 微型计算机的特点和主要性能指标有那些?【解答】除具有运算速度快、计算精度高、有记忆能力和逻辑判断能力、可自动连续工作等基本特点以外,还具有功能强、可靠性高、价格低廉、结构灵活、适应性强、体积小、重量轻、功耗低、使用和维护方便等。微型计算机的性能指标与系统结构、指令系统、硬件组成、外部设备以及软件配备等有关。常用的微型计算机性能指标主要有:字长、主频、内存容量、指令数、基本指令执行时间、可靠性、兼容性、性能价格

5、比等。1.4 常见的微型计算机硬件结构由哪些部分组成?各部分的主要功能和特点是什么?【解答】微型计算机硬件一般由微处理器、内存储器、外存储器、系统总线、接口电路、输入/输出设备等部件组成。主要组成部件的功能和特点分析如下:(1)微处理器:是微型计算机的核心部件,由运算单元alu、控制单元、寄存器组以及总线接口部件等组成,其功能是负责统一协调、管理和控制系统中的各个部件有机地工作。(2)内存储器:用来存放计算机工作过程中需要的操作数据和程序。可分为随机存储器ram和只读存储器rom。ram存放当前参与运行的各种程序和数据,特点是信息可读可写,存取方便,但信息断电后会丢失;rom用于存放各种固定的

6、程序和数据,特点是信息固定不变,关机后原存储的信息不会丢失。(3)系统总线:是cpu与其它部件之间传送数据、地址和控制信息的公共通道。可分成数据总线db、地址总线ab、控制总线cb。(4)输入/输出接口电路:完成微型计算机与外部设备之间的信息交换。由寄存器组、专用存储器和控制电路等组成。(5)主机板:由cpu插座、芯片组、内存插槽、系统bios、cmos、总线扩展槽、串行/并行接口、各种跳线和一些辅助电路等硬件组成。(6)外存储器:使用最多的是磁盘存储器(软盘、硬盘)和光盘存储器。外存储器容量大,保存的信息不会丢失。(7)输入/输入设备:是微型计算机系统与外部进行通信联系的主要装置。常用的有键

7、盘、鼠标、显示器、打印机和扫描仪等。1.5 什么是微型计算机的系统总线?说明数据总线、地址总线、控制总线各自的作用。【解答】系统总线是cpu与其它部件之间传送数据、地址和控制信息的公共通道。(1)数据总线:用来传送数据,主要实现cpu与内存储器或i/o设备之间、内存储器与i/o设备或外存储器之间的数据传送。(2)地址总线:用来传送地址。主要实现从cpu送地址至内存储器和i/o设备,或从外存储器传送地址至内存储器等。(3)控制总线:用于传送控制信号、时序信号和状态信息等。1.6 什么是系统的主机板?由哪些部件组成?【解答】cpu、ram、rom、i/o接口电路以及系统总线组成的计算机装置称为“主

8、机”,主机的主体则是主机板。主机板上主要有cpu插座、芯片组、内存插槽、系统bios、cmos、总线扩展槽、串行/并行接口、各种跳线和一些辅助电路等硬件。1.7 计算机中有哪些常用的数制和码制?如何进行数制之间的转换?【解答】数值数据经常用二进制、十进制、八进制和十六进制;字符数据使用ascii码;表示十进制数字用bcd码。(1)十进制到二进制:整数部分连续除以2后“倒取余”,小数部分连续乘以2后“正取整”;(2)二进制到十进制:将二进制数按权展开即可。(3)二进制到八进制:将3位二进制一组对应1位八进制数码。(4)八进制到二进制:将1位八进制数码对应3位二进制数码。十六进制与二进制间转换与八

9、进制与二进制间转换类似,只是比例关系为1位十六进制数码对应4位二进制数码。1.8 将下列十进制数分别转化为二进制数、十六进制数和压缩bcd码。(1)15.32 (2)325.16 (3)68.31 (4)214.126 【解答】:(1)15.32 = 1111.0101b = f.5h=00010101.00110010bcd。(2)325.16 = 10000101.0001b = 85.1h= 001100100101.00010110bcd。(3)68.31 = 1000100.0100b = 64.4h= 01101000.00110001bcd。(4)214.126 = 110101

10、10.0010b = d6.2h= 001000010100.000100100110bcd。1.9 将下列二进制数分别转化为十进制数、八进制数和十六进制数。(1)10010101 (2)11001010 (3)10111.1101 (4)111001.0101【解答】(1) 11001010 = 202 = 312q = cah(2) 10111.1101 = 23.8125 = 27.64q = 17.dh(3) 111001.0101 = 57.625 = 71.24q = 39.5h1.10 将下列十六进制数分别转化为二进制数、十进制数。(1)fah (2)12b8h (3)5a8.6

11、2h(4)2df.2h【解答】(1) fah = 11111010b = 250(2) 12b8h = 0001001010111000b = 4792(3) 5a8.62h = 010110101000.01100010b = 1448.3828125(4) 2df.2h = 001011011111.0010b = 735.00781251.11 写出下列带符号十进制数的原码、反码、补码表示(采用8位二进制数)。(1)+38 (2)+82 (3)57 (4)115【解答】(1)x =+38,x补 = 00100110b(2)x =+82,x补 = 01010010b(3)x =57,x补

12、= 11000111b(4)x =115,x补 = 10001101b1.12 写出下列二进制数的补码表示。(1)+1010100 (2)+1101101 (3) 0110010 (4) 1001110【解答】(1)x = +1010100,x补 = 01010100b(2)x = +1101101,x补 = 01101101b(3)x = 0110010,x补 = 11001110b(4)x = 1001110,x补 = 10110010b1.13 已知下列补码求出其真值。(1)87h (2)3dh (3)0b62h (4)3cf2h【解答】(1) x补 =87h = 10000111b,符

13、号位为1,x是负数,x原 =11111001b,x =-79h(2) x补 =3dh = 00111101b,符号位为0,x是正数,x = 3dh(3) x补 =0b62h =0000101101100010b,符号位为0,x是正数,x = +b62h(4) x补 =3cf2h = 0011110011110010b,符号位为0,x是正数,x =3cf2h1.14 按照字符所对应的ascii码表示,查表写出下列字符的ascii码。a 、g 、w、*、esc、lf、cr 、%【解答】a的ascii码为41h;g的ascii码为47h;w的ascii码为57h;*的ascii码为2ah;esc的a

14、scii码为1bh;lf的ascii码为0ah;cr的ascii码为dh;%的ascii码为25h。1.15 把下列英文单词转换成ascii编码的字符串。(1)how(2)great (3)water (4)good 【解答】(1)how的ascii码为486f77h;(2)great的ascii码为4772656174h;(3)water的ascii码为5761746572h;(4)good的ascii码为476f6f64h。习题22.1 8086cpu具有 20 条地址线,可直接寻址 1mb 容量的内存空间,在访问i/o端口时,使用地址线 16条 ,最多可寻址 64k 个i/o端口。 2.

15、2 8086cpu的内部结构有何特点?由哪两部分组成?它们的主要功能是什么?【解答】8086微处理器是典型的16位微处理器,hmos工艺制造,集成了2.9万只晶体管,使用单一的+5v电源,有16根数据线和20根地址线;通过其16位的内部数据通路与设置指令预取队列的流水线结构结合起来而获得较高的性能。8086微处理器内部安排了两个逻辑单元,即执行部件eu和总线接口部件biu。eu主要负责指令译码、执行和数据运算,包括计算有效地址;biu主要完成计算物理地址、从内存中取指令、实现指令规定的读/写存储器或外部设备等信息传输类操作。2.3 8086cpu中的指令队列的作用是 预取指令 ,其长度是 6

16、字节。2.4 8086cpu内部寄存器有哪几种?各自的特点和作用是什么?【解答】cpu有14个内部寄存器,可分为3大类:通用寄存器、控制寄存器和段寄存器。通用寄存器是一种面向寄存器的体系结构,操作数可以直接存放在这些寄存器中,既可减少访问存储器的次数,又可缩短程序的长度,提高了数据处理速度,占用内存空间少。控制寄存器包括指令指针寄存器ip和标志寄存器flag:ip用来指示当前指令在代码段的偏移位置;flag用于反映指令执行结果或控制指令执行的形式。为了实现寻址1mb存储器空间,8086cpu将1mb的存储空间分成若干个逻辑段进行管理,4个16位的段寄存器来存放每一个逻辑段的段起始地址。2.5

17、8086的标志寄存器分为 6 个 状态 标志位和 3 个 控制 标志位,它们各自的含义和作用是什么?【解答】标志寄存器各标志位的含义和作用如下表:表2-1 标志寄存器flag中标志位的含义和作用标志位含义作用cf进位标志cf=1,指令执行结果在最高位上产生一个进位或借位;cf=0,则无进位或借位产生pf奇偶标志pf=1,结果低8位含偶数个1;pf=0,表示结果低8位含奇数个1af辅助进位标志af=1,运算结果的低4位产生了一个进位或借位;af=0,则无此进位或借位zf零标志zf=1,运算结果为零;zf=0,则运算结果不为零sf符号标志sf=1,运算结果为负数;sf=0,则结果为正数of溢出标志

18、of=1,带符号数在进行运算时产生了溢出;of=0,则无溢出tf陷阱标志tf=1,8086cpu处于单步工作方式;tf=0,8086cpu正常执行程序if中断允许标志if=1,允许cpu接受外部从intr引脚上发来的可屏蔽中断请求信号;if=0,则禁止接受可屏蔽中断请求df方向标志df=1,字符串操作指令按递减的顺序对字符串进行处理;df=0,字符串操作指令按递增的顺序进行处理2.6 已知堆栈段寄存器(ss)=2400h,堆栈指针(sp)=1200h,计算该堆栈栈顶的实际地址,并画出堆栈示意图。【解答】(ss)=2400h,(sp)=1200h图2-1 堆栈示意图sp堆栈段栈底;pa=(ss)

19、10h(sp)= 2400h10h1200h = 25200h。2.7 8086的存储器采用 奇偶存储体 结构,数据在内存中的存放规定是 低字节存放在低地址中,高字节存放在高地址中,以低地址为字的地址,规则字是指 低字节地址为偶地址的字,非规则字是指 低字节的地址为奇地址的字。2.8 解释逻辑地址、偏移地址、有效地址、物理地址的含义,8086存储器的物理地址是如何形成的?怎样进行计算?【解答】逻辑地址:表示为段地址:偏移地址,书写程序时用到,一个存储单元可对应出多个逻辑地址;偏移地址:是某一存储单元距离所在逻辑段的开始地址的字节个数。有效地址:是指令中计算出的要访问的存储单元的偏移地址。物理地

20、址:是cpu访问存储器时用到的20位地址,是存储单元的唯一的编号。物理地址计算公式:物理地址 = 段地址10h有效地址(或偏移地址)2.9 8086系统中的存储器分为几个逻辑段?各段之间的关系如何?每个段寄存器的作用是什么?【解答】8086cpu将1mb的存储空间分成逻辑段来进行管理:每个逻辑段最小为16b。所以最多可分成64k个段;每个逻辑段最大为64kb,最少可分成16个逻辑段。各段的起始位置由程序员指出,可以彼此分离,也可以首尾相连、重叠或部分重叠。4个16位的段寄存器用来存放每一个逻辑段的段起始地址:cs中为代码段的起始地址;ds中为数据段的起始地址;ss中为堆栈段的起始地址;es中为

21、附加段的起始地址。2.10 i/o端口有哪两种编址方式,各自的优缺点是什么?【解答】i/o端口有两种编址方式:统一编址和独立编址。统一编址方式是将i/o端口与内存单元统一起来进行编号,即包括在1mb的存储器空间中,看作存储器单元,每个端口占用一个存储单元地址。该方式主要优点是不需要专门的i/o指令,对i/o端口操作的指令类型多;缺点是端口要占用部分存储器的地址空间,不容易区分是访问存储器还是外部设备。独立编址的端口单独构成i/o地址空间,不占用存储器地址。优点是地址空间独立,控制电路和地址译码电路简单,采用专用的i/o指令,使得端口操作的指令在形式上与存储器操作指令有明显区别,程序容易阅读;缺

22、点是指令类别少,一般只能进行传送操作。2.11 8086的最大工作模式和最小各种模式的主要区别是什么?如何进行控制?【解答】两种模式的主要区别是:8086工作在最小模式时,系统只有一个微处理器,且系统所有的控制信号全部由8086 cpu提供;在最大模式时,系统由多个微处理器/协处理器构成的多机系统,控制信号通过总线控制器产生,且系统资源由各处理器共享。8086cpu工作在哪种模式下通过cpu的第33条引脚mn/来控制:mn/=1,系统就处于最小工作模式;mn/=0,系统处于最大工作模式。2.12 在内存有一个由20个字节组成的数据区,其起始地址为1100h:0020h。计算出该数据区在内存的首

23、末单元的实际地址。【解答】逻辑地址1100h:0020h对应的物理地址为pa=1100h10h0020h= 11020h,即该数据区在内存中的首单元的物理地址为11020h;因为存储空间中每个字节单元对应一个地址,所以20个字节对应20个地址,则该数据区在内存中的末单元的物理地址pa = 11020h20d = 11020h14h = 11034h。2.13 已知两个16位的字数据268ah和357eh,它们在8086存储器中的地址分别为00120h和00124h,试画出它们的存储示意图。【解答】存储示意图参见图2-2。8ah00120h50h00510h26h00121h65h00511h0

24、0122h6eh00512h00123h74h00513h7eh00124h69h00514h35h00125h75h00515h6dh00516h图2-2 数据的存储示意 图2-3 字符的存储示意2.14 找出字符串“pentium”的ascii码,将它们依次存入从00510h开始的字节单元中,画出它们存放的内存单元示意图。 【解答】存储示意图参见图2-3。2.15 在内存中保存有一个程序段,其位置为(cs)=33a0h,(ip)=0130h,当计算机执行该程序段指令时,分析实际启动的物理地址是多少。【解答】逻辑地址(cs):(ip)= 33a0h:0130h,计算出对应物理地址pa= (c

25、s)10h(ip)= 33a0h10h0130h = 33b30h2.16 什么是总线周期?8086cpu的读/写总线周期各包含多少个时钟周期?什么情况下需要插入等待周期tw,什么情况下会出现空闲状态ti?【解答】8086cpu经外部总线对存储器或i/o端口进行一次信息的输入或输出过程所需要的时间,称为总线周期。8086cpu的读/写总线周期通常包括t1、t2、t3、t4状态4个时钟周期。在高速的cpu与慢速的存储器或i/o接口交换信息时,为了防止丢失数据,会由存储器或外设通过ready信号线,在总线周期的t3和t4之间插入1个或多个必要的等待状态tw,用来进行必要的时间补偿。在biu不执行任

26、何操作的两个总线周期之间会出现空闲状态ti。习题33.1 简要分析8086的指令格式由哪些部分组成,什么是操作码?什么是操作数?寻址和寻址方式的含义是什么?8086指令系统有哪些寻址方式?【解答】8086的指令格式由操作码和操作数字段组成。操作码:要完成的操作。操作数:参与操作的对象。寻址:寻找操作数或操作数地址的过程。寻址方式:指令中给出的找到操作数或操作数地址采用的方式。8086指令系统的寻址方式主要有立即数寻址、寄存器寻址、存储器寻址和i/o端口寻址。其中,存储器寻址可进一步分为直接寻址、寄存器间接寻址、寄存器相对寻址、基址变址寻址、相对基址变址寻址;i/o端口指令in和out使用的端口

27、寻址方式有直接寻址和间接寻址。3.2 设(ds)=2000h,(es)= 2100h,(ss)= 1500h,(si)= 00a0h,(bx)= 0100h,(bp)= 0010h,数据变量val的偏移地址为0050h,请指出下列指令的源操作数字段是什么寻址方式?它的物理地址是多少?(1) mov ax,21h (2) mov ax,bx (3) mov ax,1000h(4) mov ax,val (5) mov ax,bx (6) mov ax,es:bx(7) mov ax,bp (8) mov ax,si (9) mov ax,bx+10(10) mov ax,valbx (11) m

28、ov ax,bxsi (12) mov ax,valbxsi【解答】(1) mov ax,21h立即寻址,源操作数直接放在指令中(2) mov ax,bx寄存器寻址,源操作数放在寄存器bx中(3) mov ax,1000h直接寻址,ea = 1000h,pa =(ds)10hea = 2000h10h1000h = 21000h(4) mov ax,val直接寻址,ea = val = 0050h,pa =(ds)10hea = 2000h10h0050h = 20050h(5) mov ax,bx寄存器间接寻址,ea =(bx)= 0100h,pa =(ds)10hea = 2000h10h

29、0100h = 20100h(6) mov ax,es:bx寄存器间接寻址,ea =(bx)= 0100h,pa =(es)10hea = 2100h10h0100h = 21100h(7) mov ax,bp寄存器间接寻址,ea =(bp)= 0010h,pa =(ss)10hea = 1500h10h0010h = 15010h(8) mov ax,si寄存器间接寻址,ea =(si)= 00a0h,pa =(ds)10hea = 2000h10h00a0h = 200a0h(9) mov ax,bx+10相对寄存器寻址,ea =(bx)10d = 0100h000ah= 010ah,pa

30、 =(ds)10hea = 2000h10h010ah = 2010ah(10) mov ax,valbx相对寄存器寻址,ea =(bx)val= 0100h0050h= 0150h,pa =(ds)10hea = 2000h10h0150h = 20150h(11) mov ax,bxsi基址变址寻址,ea = (bx)(si)= 0100h00a0h = 01a0h,pa = (ds)10hea = 2000h10h01a0h = 201a0h(12) mov ax,valbxsi相对基址变址寻址,ea = (bx)(si)val= 0100h00a0h0050h = 01f0h,pa =

31、(ds)10hea = 2000h10h01f0h = 201f0h3.3 给定寄存器及存储单元的内容为:(ds) = 2000h,(bx) = 0100h,(si) = 0002h,(20100) = 32h,(20101) = 51h,(20102) = 26h,(20103) = 83h,(21200) = 1ah,(21201) = b6h,(21202) = d1h,(21203) = 29h。试说明下列各条指令执行完后,ax寄存器中保存的内容是什么。(1) mov ax,1200h (2) mov ax,bx (3) mov ax,1200h(4) mov ax,bx (5) mo

32、v ax,1100hbx (6) mov ax,bxsi【解答】(1) mov ax,1200h ;执行后,(ax)= 1200h(2) mov ax,bx ;执行后,(ax)= (bx)= 0100h(3) mov ax,1200h 直接寻址,ea = val = 1200h,pa =(ds)10hea = 2000h10h1200h = 21200h,执行后,(ax)= b61ah(4) mov ax,bxea = (bx)= 0100h,pa =(ds)10hea = 2000h10h0100h = 20100h,执行后,(ax)= 5132h(5) mov ax,1100hbxea =

33、(bx)1100h = 0100h1100h = 1200h,pa =(ds)10hea = 2000h10h1200h = 21200h,执行后,(ax)= b61ah(6) mov ax,bxsiea =(bx)(si)= 0100h0002h = 0102h,pa =(ds)10hea = 2000h10h0102h = 20102h,执行后,(ax)= 29d1h3.4 分析下列指令的正误,对于错误的指令要说明原因并加以改正。(1) mov ah,bx (2) mov bx,si(3) mov ax,sidi (4) mov mydatbxsi,es:ax(5) mov byte pt

34、rbx,1000 (6) mov bx,offset maydatsi (7) mov cs,ax (8) mov ds,bp【解答】(1) mov ah,bx 错误,寄存器类型不匹配,可改为mov ax,bx(2) mov bx,si错误,两个操作数不能都为存储单元,可改为mov bx,si或mov bx,si(3) mov ax,sidi错误,寻址方式中只能出现一个变址寄存器,可改为mov ax,bxdi。(4) mov mydatbxsi,es:ax错误,ax签不能有段跨越前缀,去掉es:,改为mov mydatbxsi,ax(5) mov byte ptrbx,1000错误,1000超

35、出字节空间存储范围(6) mov bx,offset maydatsi ;正确(7) mov cs,ax错误,mov指令cs不能做目的操作数,可改为mov ds,ax(8) mov ds,bp ;正确注:本题错误改正部分有的答案并不唯一,可参考原题题意改成合法形式。3.5 设var1、var2为字变量,lab为标号,分析下列指令的错误之处并加以改正。(1) add var1,var2 (2) mov al,var2(3) sub al,var1 (4) jmp labsi(5) jnz var1 (6) jmp near lab【解答】(1) add var1,var2错误,两个操作数不能都为

36、存储单元,可改为 mov bx,var2add var1,bx(2) mov al,var2错误,数据类型不匹配,可改为mov ax,var2(3) sub al,var1错误,数据类型不匹配,可改为sub ax,var1(4) jmp labsi错误,寄存器相对寻址形式中不能用标号做位移量,可改为jmp var1si(5) jnz var1错误,条件跳转指令只能进行段内短跳转,所以后面只能跟短标号。可改为jnz lab(6) jmp near lab错误,缺少运算符ptr,可改为jmp near ptr lab注:本题错误改正部分有的答案并不唯一,可参考原题题意改成合法形式。3.6 写出能够

37、完成下列操作的8086cpu指令。(1) 把4629h传送给ax寄存器;(2) 从ax寄存器中减去3218h;(3) 把buf的偏移地址送入bx中。【解答】(1) mov ax,4629h(2) sub ax,3218h(3) lea bx,buf3.7 根据以下要求写出相应的汇编语言指令。 (1) 把bx和dx寄存器的内容相加,结果存入dx寄存器中; (2) 用bx和si的基址变址寻址方式,把存储器中的一个字节与al内容相加,并保存在al寄存器中; (3) 用寄存器bx和位移量21b5h的变址寻址方式把存储器中的一个字和(cx)相加,并把结果送回存储器单元中; (4) 用位移量2158h的直

38、接寻址方式把存储器中的一个字与数3160h相加,并把结果送回该存储器中; (5) 把数25h与(al)相加,结果送回寄存器al中。【解答】(1) add dx,bx(2) add al,bxsi(3) add 21b5hbx,cx(4) add word ptr 2158h,3160h(5) add al,25h3.8 分析汇编语言源程序应该由哪些逻辑段组成?各段的作用是什么?语句标号和变量应具备哪3种属性?【解答】汇编语言源程序应该由若干个逻辑段组成,可以有若干个数据段、代码段、堆栈段和附加数据段,至少要有一个代码段。各段的作用如下:(1)代码段用来存放程序和常数。(2)数据段用于数据的保存

39、。(3)堆栈段用于保护数据,尤其在子程序调用、中断过程中进行现场信息保护。(4)附加数据段用于数据的保存。语句标号和变量应具备的3种属性:段属性、偏移属性和类型属性。3.9 执行完下列程序后,回答指定的问题。mov ax,0mov bx,2mov cx,50lp:add ax,bxadd bx,2loop lp问:(1) 该程序的功能是 。(2) 程序执行完成后,(ax)= 。【解答】(1)完成0到100间所有偶数求和的功能。(2)25503.14 编写程序,计算下面函数的值。【解答】data segment x dw 34 s dw ?data endscode segment assume

40、 cs:code,ds:datastart:mov ax,data mov ds,ax mov ax,x ;将x送到ax中 cmp ax,0 ;(ax)0吗? jl doub ;是,转向doub cmp ax,10 ;否,(ax)10吗? jle trib ;是,转向trib sal ax,1 ;否,乘以4 sal ax,1 jmp exitdoub: sal ax,1 ;乘以2 jmp exittrib: sal ax,1 ;乘以3 add ax,xexit: mov s,ax ;保存结果 mov ah,4ch ;结束 int 21hcode ends end start注意,在比较的过程中

41、使用的是针对带符号数的跳转指令,应该看作带符号数。程序中还用了移位指令代替了乘法指令。3.16 已知在内存中从block单元起存放有20个带符号字节数据,统计其中负数的个数并放入count单元。【解答】data segment block db -7,1,12,-90,-70,34,-1,56,45,-12 db -3,-4,23,0,12,11,-9,-8,67,-56 cn equ $-block count db ?data endscode segment assume ds:data,cs:codestart:mov ax,data mov ds,ax mov dl,0 lea si

42、,block mov cx,cnlp: mov al,si test al,80h jz next inc dlnext: inc si loop lp mov count,dl mov ah,4ch int 21hcode ends end start习题44.1 半导体存储器有哪些优点?sram、dram各自有何特点?【解答】特点是容量大、存取速度快、体积小、功耗低、集成度高、价格便宜。sram存放的信息在不停电的情况下能长时间保留不变,只要不掉电所保存的信息就不会丢失。而dram保存的内容即使在不掉电的情况下隔一定时间后也会自动消失,因此要定时对其进行刷新。4.2 rom、prom、ep

43、rom、e2prom、flash memory各有何特点?用于何种场合?【解答】掩膜式rom中的信息是在生产厂家制造时写入的。制成后,信息只能读出不能改写。prom中晶体管的集电极接vcc,基极连接行线,发射极通过一个熔丝与列线相连。出厂时,晶体管阵列的熔丝完好。写入信息时,选中某个晶体管,输入高低电平保留或烧断熔丝对应1和0。烧断熔丝不能再复原,因此只能进行一次编程。eprom芯片的顶部开有一石英窗口,通过紫外线的照射可擦除片内原有信息,一块芯片可多次使用,缺点是只能进行整片写。e2prom是可用电擦除和编程的只读存储器,能在线读写,断电情况信息不丢失,能随机改写;其擦写次数可达1万次以上,

44、数据可保存10年以上。可作为系统中可靠保存数据的存储器。flash memory是新型的半导体存储器,可实现大规模电擦除,擦除功能可迅速清除整个存储器的所有内容;可高速编程;闪速存储器可重复使用,适用于文件需要经常更新的可重复编程应用中。对于需要实施代码或数据更新的嵌入性应用是一种理想的存储器。4.3 动态ram为什么需要经常刷新?微机系统如何进行动态ram的刷新?【解答】动态ram是利用电容存储电荷的原理来保存信息的,由于电容会泄漏放电,所以,为保持电容中的电荷不丢失,必须对动态ram不断进行刷新。dram的刷新常采用两种方法:一是利用专门的dram控制器实现刷新控制,如intel 8203

45、控制器;二是在每个dram芯片上集成刷新控制电路,使存储器件自身完成刷新,如intel 2186/2187。4.4 常用的存储器地址译码方式有哪几种?各自的特点是什么?【解答】线选译码:连接简单,无须专门的译码电路;缺点是地址不连续,cpu寻址能力的利用率太低,会造成大量的地址空间浪费。全译码:将低位地址总线直接连至各芯片的地址线,余下的高位地址总线全部参加译码,译码输出作为各芯片的片选信号。可以提供对全部存储空间的寻址能力。部分译码:该方法只对部分高位地址总线进行译码,以产生片选信号,剩余高位线可空闲或直接用作其它存储芯片的片选控制信号。4.5 半导体存储器在与微处理器连接时应注意哪些问题?

46、【解答】半导体存储器与cpu连接前,要确定内存容量的大小并选择存储器芯片的容量大小,要考虑存储器地址分配问题;在进行存储器地址分配时,要将rom和ram分区域安排。4.6 计算机在什么情况下需要扩展内存?扩展内存需要注意哪些问题?【解答】单个存储芯片的存储容量是有限的,因此常常需要将多片存储器按一定方式组成具有一定存储单元数的存储器。4.7 已知某微机系统的ram容量为4k8位,首地址为2600h,求其最后一个单元的地址。【解答】ram的容量为4k8位=4kb,对应的地址有4k个,首地址为2600h,则其最后一个单元的地址为2600h(4k1)= 2600h4095 = 2600hfffh =

47、 35ffh4.8 已知一个具有14位地址和8位数据的存储器,回答下列问题:(1)该存储器能存储多少字节的信息?(2)如果存储器由8k4位ram芯片组成,需要多少片?(3)需要多少位地址作芯片选择?【解答】(1)该存储器能存储的字节个数是214= 24210 = 16k。(2)该存储器能存储的总容量是16kb,若由8k4位ram芯片组成,需要的片数为(16k8)/(8k4)= 4片(3)因为该存储器中读写数据的宽度为8位,所以4片8k4位ram芯片要分成两组,用一位地址就可区分;另一方面,每一组的存储容量为8k8位 = 2138位,只需要13位地址就可完全访问。4.9 用16k1位的dram芯

48、片组成64k8位的存储器,要求画出该存储器组成的逻辑框图。【解答】总容量为64k8位,由16k1位的dram芯片组成:(64k8位)/(16k1位)= 32片既要进行位扩展又要进行字扩展:由8片组成一组进行位扩展,由这样的4组进行字扩展。每一组的存储容量为16k8位 = 16kb = 214b,需要14位地址做片内寻址;4组芯片需要2位地址做片组选择,即片选信号。逻辑框图见图4-1。为清楚起见,图中只画出了各个芯片的部分连线。4.10 若用4k1位的ram芯片组成16k8位的存储器,需要多少芯片?a19a0地址线中哪些参与片内寻址?哪些作为芯片组的片选信号?【解答】(16k8位)/(4k1位)

49、= 32片每8片一组,分成4组。每组的存储容量为4kb = 212b,片内寻址需要12位地址线,即a11a0;4组芯片可用2位地址线进行区分,即可用a13a12做片选信号,a19a14可浮空或做其他用途。4.11 若用2114芯片组成2kb ram,地址范围为3000h37ffh,问地址线应如何连接?(假设cpu有16条地址线、8条数据线)【解答】2114芯片单片容量为1k4位,组成2k8位ram需要:(2k8位)/(1k4位)= 4片每2片一组,分成2组。每组的存储容量为1kb = 210b,片内寻址需要10位地址线。对应的地址范围为3000h37ffh = 0011000000000000

50、b 0011011111111111b,可见,cpu的16条地址线中a9a0用于片内寻址,a10用做片选信号,a13a12接高电平,a15a14、a11接地。4.12 简述计算机中为什么要采用高速缓存器cache?分析其工作原理。习题55.1 什么是接口?其作用是什么?【解答】连接外部设备与微型计算机的接口电路。作用:(1)解决cpu与外设工作速度不匹配的问题;(2)解决cpu与外设工作时序配合问题;(3)实现信息格式转换;(4)解决信息类型与信号电平匹配的问题。5.2 输入/输出接口电路有哪些寄存器,各自的作用是什么?【解答】通常有数据输入、数据输出、控制和状态寄存器等。在cpu与外部设备之

51、间进行数据传输时,各类信息写入接口中相应的寄存器,或从相应寄存器读出。cpu从数据输入寄存器和状态寄存器中读出数据和状态,但不能向其中写内容; cpu往数据输出寄存器和控制寄存器中写数据和控制信息,但不能从其中读内容。5.3 什么叫端口?i/o端口的编址方式有哪几种?各有何特点? 【解答】端口指输入/输出接口中的寄存器。i/o端口有两种编址方式:统一编址方式是将i/o端口与内存单元统一起来进行编号。该方式优点是不需要专门的i/o指令,对i/o端口操作的指令类型多;缺点是端口要占用部分存储器的地址空间,不容易区分是访问存储器还是外部设备。独立编址的端口单独构成i/o地址空间,不占用存储器地址。优

52、点是地址空间独立,控制电路和地址译码电路简单,采用专用的i/o指令,使得端口操作的指令在形式上与存储器操作指令有明显区别,程序容易阅读;缺点是指令类别少,一般只能进行传送操作。5.4 cpu与输入输出设备之间传送的信息由哪几类?相应的端口称为什么端口?【解答】cpu与输入/输出设备交换的信息有3类:数据信息、状态信息和控制信息。数据信息相应的端口称为数据端口;状态信息相应的端口称为状态端口;控制信息相应的端口称为控制端口。5.5 cpu和外设之间的数据传送方式有哪几种?无条件传送方式通常用在哪些场合?【解答】cpu和外设之间的数据传送方式通常有四种:程序传送方式、中断传送方式、dma传送方式和i/o处理机方式。5.6 相对于条件传送方式,中断方式有什么优点?和dma方式比较,中断传送方式又有什么不足之处?【解答】中断传送方式下,当外设要求交换数据时,向cpu发中断请求,cpu在执行完当前指令后,即可中断当前任务的执行,并根据中断源转入相应的中断处理服务程序,实现对请求中断外设的管理。cpu与外设实现了并行工作,大大提高了工作效率。

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论