新版汇编语言程序的设计钱晓捷第4章习题答案
新版汇编语言程序设计习题答案(钱晓捷主编)电子教案
![新版汇编语言程序设计习题答案(钱晓捷主编)电子教案](https://img.taocdn.com/s3/m/07b9b81c6bec0975f565e281.png)
新版汇编语言程序设计习题答案(钱晓捷主编)新版汇编语言程序设计习题答案(钱晓捷主编)第一章汇编语言基础知识1.1、简述计算机系统的硬件组成及各部分作用1.2、明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB1.3、什么是汇编语言源程序、汇编程序、目标程序?1.4、汇编语言与高级语言相比有什么优缺点?1.5、将下列十六进制数转换为二进制和十进制表示(1)FFH (2)0H (3)5EH (4)EFH(5)2EH (6)10H (7)1FH (8)ABH1.6、将下列十进制数转换为BCD码表示(1)12 (2)24 (3)68 (4)127(5)128 (6)255 (7)1234 (8)24581.7、将下列BCD码转换为十进制数(1)10010001 (2)10001001 (3)00110110 (4)10010000(5)00001000 (6)10010111 (7)10000001 (8)000000101.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示(1)0 (2)-127 (3)127 (4)-57(5)126 (6)-126 (7)-128 (8)681.9、完成下列二进制数的运算(1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000÷1001(5)1011 ∧~1011 (8)1011 ⊕ 1001 1001(6)1011 ∨1001(7)1.10 数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展。
微机原理与接口技术(钱晓捷版)课后习题答案
![微机原理与接口技术(钱晓捷版)课后习题答案](https://img.taocdn.com/s3/m/66991782d1f34693daef3e9a.png)
“微机原理与接口技术”习题解答第1章微型计算机系统〔习题1.1〕简答题〔解答〕①处理器每个单位时间可以处理的二进制数据位数称计算机字长。
②总线信号分成三组,分别是数据总线、地址总线和控制总线。
③ PC机主存采用DRAM组成。
④高速缓冲存储器Cache是处理器与主存之间速度很快但容量较小的存储器。
⑤ ROM-BIOS是“基本输入输出系统”,操作系统通过对BIOS的调用驱动各硬件设备,用户也可以在应用程序中调用BIOS中的许多功能。
⑥中断是CPU正常执行程序的流程被某种原因打断、并暂时停止,转向执行事先安排好的一段处理程序,待该处理程序结束后仍返回被中断的指令继续执行的过程。
⑦主板芯片组是主板的核心部件,它提供主板上的关键逻辑电路。
⑧ MASM是微软开发的宏汇编程序。
⑨指令的处理过程。
处理器的“取指—译码—执行周期” 是指处理器从主存储器读取指令(简称取指),翻译指令代码的功能(简称译码),然后执行指令所规定的操作(简称执行)的过程。
⑩机器语言层,即指令集结构。
(学生很多认为是:汇编语言层。
前4章主要涉及汇编语言,但本书还有很多处理器原理等内容)〔习题1.2〕判断题①错②错③对④错⑤对⑥错⑦错⑧对⑨错⑩错〔〔解答〕① Central Processing Unit,中央处理单元,处理器② 1MB,4GB③ 216,64KB④ EXE,COM(BAT老师讲的)⑤ Instruction Set Architecture⑥目录⑦ MMX,SSE3⑧ 64⑨ IBM,DOS⑩ PCI〔习题1.4〕说明微型计算机系统的硬件组成及各部分作用。
〔解答〕CPU:CPU也称处理器,是微机的核心。
它采用大规模集成电路芯片,芯片内集成了控制器、运算器和若干高速存储单元(即寄存器)。
处理器及其支持电路构成了微机系统的控制中心,对系统的各个部件进行统一的协调和控制。
存储器:存储器是存放程序和数据的部件。
外部设备:外部设备是指可与微机进行交互的输入(Input)设备和输出(Output)设备,也称I/O设备。
汇编语言程序设计(第四版)第4章【课后答案】
![汇编语言程序设计(第四版)第4章【课后答案】](https://img.taocdn.com/s3/m/f302d09a102de2bd960588ab.png)
汇编语言程序设计(第四版)第4章【课后答案】汇编语言程序设计第四版【课后习题答案】--囮裑為檤第4章基本汇编语言程序设计〔习题4.1〕例题4.2如果要求算术右移8位,如何修改程序。
〔解答〕思路:首先由最高位字节向次低位字节传送……次低位字节向最低位字节传送(共7次);再判最高位字节符号位,如为0,送00h到最高位字节;如为1,送ffh到最高位字节。
传送可参考例题4.2,不过应从第一号字节送第零号字节,……最高位字节向次低位字节传送;也可以用循环来完成:.model small.stack 256.dataqvar dq 1234567887654321h.code.startupmov cx,7mov si,1again: mov al, byte ptr qvar[si]mov byte ptr qvar[si-1],alinc siloop againtest al,80hjz ezzmov bl,0ffhjmp doneezz: mov bl,0done: mov byte ptr qvar[7],bl.exit 0end〔习题4.2〕例题4.2如果要求算术左移7位,如何用移位指令实现。
〔解答〕思路:可设计外循环体为8个字节左移一次,方法是:最低位字节算术左移一次,次低位字节至最高位字节依次带CF 位循环左移一次(内循环共8次),外循环体控制执行7次即可。
.model small.stack 256.dataqvar dq 1234567887654321h.code.startupmov dx, 7 ;外循环次数mov ax, byte ptr qvar[0] ;最低位字节送axlpp: shl ax, 1 ;最低位字节左移一次,其d7移入CF位mov si, 1mov cx, 7 ;内循环次数again: rcl byte ptr qvar[si], 1 ;高位字节依次左移P50inc siloop againdec dxjnz lpp.exit 0.end〔习题4.3〕将AX寄存器中的16位数连续4位分成一组,共4组,然后把这4组数分别放在AL、BL、CL和DL寄存器中。
钱晓捷新版汇编语言程序设计习题答案(1-4)
![钱晓捷新版汇编语言程序设计习题答案(1-4)](https://img.taocdn.com/s3/m/06d3771b5f0e7cd1842536cb.png)
钱晓捷新版汇编语言程序设计习题答案第一章汇编语言基础知识1.17、举例说明CF和OF标志的差异。
溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出范围,运算结果已经不正确•例1:3AH + 7CH=B6H无符号数运算:58+124=182,范围内,无进位有符号数运算: 58+124=182 ,范围外,有溢出•例2:AAH + 7CH=(1)26H无符号数运算:170+124=294,范围外,有进位有符号数运算:-86+124=28 ,范围内,无溢出1.20、8086有哪4种逻辑段,各种逻辑段分别是什么用途?(解答)代码段(Code Segment)用来存放程序的指令序列。
处理器利用CS : IP取得下一条要执行的指令•堆栈段(Stack Segment)确定堆栈所在的主存区域。
处理器利用SS : SP操作堆栈中的数据•数据段(Data Segment)存放当前运行程序所用的数据。
处理器利用DS : EA存取数据段中的数据•附加段(Extra Segment)是附加的数据段,也用于数据的保存。
处理器利用ES : EA存取数据段中的数据第二章8086指令系统2.1已知DS = 2000H、BX = 0100H、SI = 0002H,存储单元[20100H] ~ [20103H]依次存放12 34 56 78H,[21200H] ~ [21203H]依次存放2A 4C B7 65H,说明下列每条指令执行完后AX寄存器的内容。
(1) mov ax,1200h ;AX=1200h(2) mov ax,bx ; AX=0100h(3) mov ax,[1200h] ; AX=4C2Ah(4) mov ax,[bx] ; AX=3412h(5) mov ax,[bx+1100h] ; AX=4C2Ah(6) mov ax,[bx+si] ; AX=7856h(7) mov ax,[bx][si+1100h] ; AX=65B7h2.2指出下列指令的错误(1) mov cx,dl 两操作数类型不匹配(2) mov ip,ax IP 指令指针禁止用户访问(3) mov es,1234h 立即数不允许传给段寄存器(4) mov es,ds 段寄存器之间不允许传送(5) mov al,300 两操作数类型不匹配(6) mov [sp],ax 目的操作数应为[ BP ](7) mov ax,bx+di 源操作数应为 [BX+DI](8) mov 20h,ah 立即数不能作目的操作数2.3已知数字0 ~ 9对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址(设为200H)的连续区域中。
新版汇编语言程序设计1-5章【课后答案】
![新版汇编语言程序设计1-5章【课后答案】](https://img.taocdn.com/s3/m/b639ccec551810a6f524863b.png)
新版汇编语言程序设计【课后习题答案】第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成及各部分作用。
〔解答〕CPU:包括运算器、控制器和寄存器组。
运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。
存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。
外部设备:实现人机交换和机间的通信。
〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU 可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。
辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。
RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息。
存储器由大量存储单元组成。
为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口。
KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位。
〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。
〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。
汇编语言程序设计习题答案
![汇编语言程序设计习题答案](https://img.taocdn.com/s3/m/18ee8420f011f18583d049649b6648d7c1c7083f.png)
第一章微型计算机系统概述1.3习题与综合练习1.解释和区别下列名词术语(1)微处理器(MP):具有中央处理器功能的大规模集成电路器件微型计算机(MC)微型计算机系统(MCS)(2)硬件:硬件是计算机系统的躯体,由控制器,运算器,存储器,输入设备,输出设备5大部分组成。
软件:软件是计算机的头脑和灵魂,可分为系统软件和应用软件。
(3)字节:8位二进制是一个字节。
字:16位二进制构成一个字。
字长:计算机的运算部件能同时处理的二进制数据的位数。
(4)指令指针:存放BIU要取的下一条指令的偏移地址。
指令寄存器:指令译码器:状态寄存器:(5)存储单元:存储内容:存储地址:存储容量:(6)RAM:ROM:软件固化:2.冯·诺依曼计算机结构的特点是什么?(1)采用二进制数的形式表示数据和指令。
(2)将指令和数据存放在存储器中。
(3) 计算机硬件由控制器,运算器,存储器,输入设备和输出设备5大部分组成。
3.件数计算机系统中复杂指令集和精简指令集的特点和用途。
复杂指令集(CISC):在微型计算机的体系结构组成结构上是以复杂指令为设计的计算机,在指令的运行过程中按指令的复杂程度来指挥计算机完成各条指令,由于各条指令复杂程度不同分配的时钟周期各不相同,执行指令所需时间就不相同。
CISC体系的指令集由微程序来实现,即每一个操作由若干微操作的程序组合来实现。
所以CISC可以使用微指令编程的方式实现多种和功能复杂的指令。
精简指令系统(RISC):不管计算机的指令如何复杂,在一个计算机时钟周期内完成,计算速度快,指令集简单。
每一条指令直接有硬布线实现,即它的每条指令原则上有自己的一套逻辑时序电路直接实现,所以单条指令的实现所占用的硬件资源较多。
因为该体系没有能采用增加单条指令的功能或高位的指令语义,也没有增加指令的条数,而是集中于它的精简指令集上。
4.CPU是计算机系统中的重要部件,试说明CPU的结构和功能。
微处理器是计算机中最关键的部件,由控制器,运算器,寄存器组和辅助部件组成。
《汇编语言程序设计》(第四版)教案及答案解析
![《汇编语言程序设计》(第四版)教案及答案解析](https://img.taocdn.com/s3/m/c9b188ee0508763231121222.png)
《汇编语言程序设计》教案附:习题参考答案《汇编语言程序设计》(第4版)钱晓捷主编前言1.汇编语言是计算机能提供给用户的最快而又最有效的语言,也是能够利用计算机所有硬件特性并能直接控制硬件的唯一语言。
2.汇编语言程序设计是高等院校电子计算机硬、软件及应用专业学生必修的核心课程之一。
它不仅是计算机原理、操作系统等其它核心课程的必要先修课,而且对于训练学生掌握程序设计技术、熟悉上机操作和程序调试技术都有重要作用。
3.本教材共有十一章,其内容安排如下:(1).第一、二章为汇编语言所用的基础知识。
(2).第三章详细介绍80x86系列CPU的指令系统和寻址方式。
(3).第四章介绍伪操作、汇编语言程序格式及汇编语言的上机过程。
(4).第五、六章说明循环、分支、子程序结构和程序设计的基本方法。
(5).第七章说明宏汇编、重复汇编及条件汇编的设计方法。
(6).第八章叙述输入/输出程序设计方法,重点说明中断原理、中断过程及中断程序设计方式。
(7).第九章说明BIOS和DOS系统功能调用的使用方法。
(8).第十~十一章分别说明图形显示、发声及磁盘文件存储的程序设计方法,同时提供各种程序设计方法和程序实例。
附:教学参考书1.沈美明、温冬婵编著,IBM–PC汇编语言程序设计(第2版),清华大学出版社,2001年(教材)2.沈美明、温冬婵编著,IBM–PC汇编语言程序设计,清华大学出版社,1991年3.沈美明、温冬婵编著,IBM–PC汇编语言程序设计—例题习题集,清华大学出版社,1991年6月4.沈美明、温冬婵、张赤红编著,IBM–PC汇编语言程序设计—实验教程,清华大学出版社,1992年5.周明德,微型计算机IBM PC/XT(0520系列)系统原理及应用(修订版),清华大学出版社,19916.郑学坚、周斌,微型计算机原理及应用(第二版),清华大学出版社,19957.王士元、吴芝芳,IBM PC/XT[长城0520] 接口技术及其应用,南开大学出版社,19908.杨素行,微型计算机系统原理及应用,清华大学出版社,19959.戴梅萼、史嘉权,微型计算机技术及应用—从16位到32位(第二版),清华大学出版社,199610.张昆藏,IBM PC/XT微型计算机接口技术,清华大学出版社,199111.孟绍光,李维星,高档微机组成原理及接口技术(80386/80486/Pentium),学苑出版社,199312.吴秀清,周荷琴,微型计算机原理与接口技术,中国科学技术大学出版社目录第 1 章基础知识 (1)1.1进位计数制与不同基数的数之间的转换 (1)1.2二进制数和十六进制数的运算 (2)1.3计算机中数和字符的表示 (3)1.4几种基本的逻辑运算 (3)第 2 章 80X86计算机组织 (4)2.180X86微处理器 (4)2.2基于微处理器的计算机系统构成 (4)2.3中央处理机 (5)2.4存储器 (6)2.5外部设备 (7)第 3 章 80X86的指令系统和寻址方式 (8)3.180X86的寻址方式 (8)3.2程序占有的空间和执行时间 (10)3.380X86的指令系统 (10)第 4 章汇编语言程序格式 (27)4.1汇编程序功能 (27)4.2伪操作 (27)4.3汇编语言程序格式 (31)4.4汇编语言程序的上机过程 (34)第 5 章循环与分支程序设计 (37)5.1循环程序设计 (37)5.2分支程序设计 (38)5.3如何在实模式下发挥80386及其后继机型的优势 (38)第 6 章子程序结构 (40)6.1子程序的设计方法 (40)6.2子程序的嵌套 (41)6.3子程序举例 (41)第 7 章高级汇编语言技术 (43)7.1宏汇编 (43)7.2重复汇编 (44)7.3条件汇编 (45)第 8 章输入/输出程序设计 (46)8.1I/O设备的数据传送方式 (46)8.2程序直接控制I/O方式 (47)8.3中断传送方式 (47)第 9 章 BIOS和DOS中断 (50)9.1键盘I/O (50)9.2显示器I/O (52)9.3打印机I/O (53)9.4串行通信口I/O (54)第 10 章图形与发声系统的程序设计 (55)10.1显示方式 (55)10.2视频显示存储器 (55)10.3EGA/VGA图形程序设计 (56)10.4通用发声程序 (57)10.5乐曲程序 (58)第 11 章磁盘文件存取技术 (59)11.1磁盘的记录方式 (59)11.2文件代号式磁盘存取 (60)11.3字符设备的文件代号式I/O (61)11.4BIOS磁盘存取功能 (62)附录:《IBM—PC汇编语言程序设计》习题参考答案 (63)第一章.习题 (63)第二章.习题 (64)第三章.习题 (65)第四章.习题 (79)第五章.习题 (84)第六章.习题 (104)第七章.习题 (118)第八章.习题 (125)第九章.习题 (130)第十章.习题 (134)第十一章.习题 (145)第 1 章 基础知识【教学目的】本章内容是本课程的基础,通过本章学习,使学生明确汇编语言程序设计的学科性质、基本内容和学习意义,掌握数制的转换、数据的编码,了解本门课程的教学要求和学习方法。
32位汇编语言程序设计部分课后习题答案
![32位汇编语言程序设计部分课后习题答案](https://img.taocdn.com/s3/m/b74e35d0941ea76e58fa04da.png)
习题解答
1.3 填空题-1
(3)IA-32处理器有8个32位通用寄存器,其中EAX, ___,___和EDX,可以分成16位和8位操作;还有另 外4个是___,___,___,和___。 • EBX,ECX,ESI,EDI,EBP,ESP (4)寄存器EDX是___位的,其中低16位的名称是____, 还可以分成两个8位的寄存器,其中D0~D7和D8~ D15部分可以分别用名称____和____表示。 • 32,DX,DL,DH (5)IA-32处理器有___个段寄存器,它们都是_____ 位的。 • 6,16
17
习题解答
2.3 填空题-2
(3)定义字节变量的伪指令助记符是______,获取变 量名所具有的偏移地址的操作符是_______。 • BYTE,OFFSET (8)指令“MOV EAX, OFFSET MSG”的目的操作数和 源操作数分别采用______和_______寻址方式。 • 寄存器寻址,立即数寻址 (9)已知ESI=04000H,EBX=20H,指令“MOV EAX, [ESI+EBX*2+8]”中访问的有效地址是__________。 • 04000H+20H×2+8=04048H
3
习题解答
1.1 简答题-2
(7)汇编语言中的标识符与高级语言的变量和常量名 的组成原则有本质的区别吗? • 没有 (8)汇编语言的标识符大小写不敏感意味着什么? • 表示字母大小写不同、但表示同一个符号
4
习题解答
1.2 判断题
1)EAX也被称为累加器,因为它使用最频繁。 • 对,EAX中的A来自英文累加器(Accumulator) 6)处理器的传送指令MOV属于汇编语言的执行性语句 •对 7)汇编语言的语句由明显的4部分组成,不需要分隔 符区别。 • 错,使用了分隔符才有了明显的4部分 8)MASM汇编语言的注释用分号开始,不能用中文分号 • 对,源程序中的分隔符以及各种标识符都是英文 9)程序终止执行也就意味着汇编结束,所以两者含义 相同。 • 错,两者完全是两个概念
汇编语言程序设计(第四版)第4章【课后答案】【精选】
![汇编语言程序设计(第四版)第4章【课后答案】【精选】](https://img.taocdn.com/s3/m/195757a568dc5022aaea998fcc22bcd126ff4293.png)
汇编语言程序设计 第四版【课后习题答案】--囮裑為檤第4章 基本汇编语言程序设计〔习题4.1〕例题4.2如果要求算术右移8位,如何修改程序。
〔解答〕思路: 首先由最高位字节向次低位字节传送……次低位字节向最低位字节传送(共7次);再判最高位字节符号位,如为0,送00h 到最高位字节;如为1,送ffh 到最高位字节。
传送可参考例题4.2,不过应从第一号字节送第零号字节,……最高位字节向次低位字节传送;也可以用循环来完成: .model small .stack 256 .dataqvar dq 1234567887654321h .code .startup mov cx,7 mov si,1again: mov al, byte ptr qvar[si] mov byte ptr qvar[si-1],al inc siloop again test al,80h jz ezzmov bl,0ffh jmp done ezz: mov bl,0done: mov byte ptr qvar[7],bl .exit 0 end〔习题4.2〕例题4.2如果要求算术左移7位,如何用移位指令实现。
〔解答〕思路:可设计外循环体为8个字节左移一次,方法是:最低位字节算术左移一次, 次低位字节至最高位字节依次带 CF 位循环左移一次(内循环共8次),外循环体控制执行7次即可。
.model small .stack 256 .dataqvar dq 1234567887654321h4 11 201628.code.startupmov dx, 7 ;外循环次数mov ax, byte ptr qvar[0] ;最低位字节送axlpp: shl ax, 1 ;最低位字节左移一次,其d7移入CF 位 mov si, 1mov cx, 7 ;内循环次数again: rcl byte ptr qvar[si], 1 ;高位字节依次左移 P50 inc siloop again dec dx jnz lpp .exit 0 .end〔习题4.3〕将AX 寄存器中的16位数连续4位分成一组,共4组,然后把这4组数分别放在AL 、BL 、CL 和DL 寄存器中。
汇编语言程序设计课后习题答案
![汇编语言程序设计课后习题答案](https://img.taocdn.com/s3/m/b5230c4f561252d380eb6eea.png)
第四章汇编语言程序设计习题答案一、单项选择题1.C2.B3.C4.C5.C6.A7.A8.C9.B10. D11.B12.B13.D14.C15.C16.A17.D18.D19.A20. C21.B22.D23.D24. A二、多项选择题1.ABCEF2.ACE3.AC4.ABCD三、填空题1.PARA2.1,2,60,120, 13.SEGMENT,ENDS4.12005.段内转移,段间转移6.AH7.过程,PROC,RET,NEAR,FAR8.LEA BX,BUF9.1, 410..0504H11.ASM,EXE12.立即寻址,直接寻址四、判断题××××V V V××V五、程序分析题1. 32.12H,3412H3.46H,73H4.(1) 从目的串中查找是否包含字符‘0’,若找到则停止,否则继续重复搜索。
(2) ZF=1, 说明已找到字符ZF=0, 说明未找到字符CX 0,说明中途已找到字符退出CX=0,且ZF=0说明串中无字符‘0’5.1, 0, 3, 2, 5, 4, 7, 6, 9, 86.87H,81H7.44AAH,44D5H8.DEC CX,JNC,JZ9.JNZ L210.ADC DX,0,CLC11.AAS12.STOSB13.1,3,1,2, 214.(2000H)=39H (2001H)=00H将(2000H),(2001H)两相邻单元中存放的未组合型BCD码压缩成组合型BCD码,并存入(2000H)单元,0 (2001H)15.A)2345H,6780HB)将DX、AX中存放的32位二进制数向左移动4位16.0 ,1009H0对数据段内1000H~1008H单元置数,依次送入1,2,4,8,16,32,64,128,0共九个17.20H,10,T18.①$-BUF②ASSUME CS:CODE,DS:DATA③MOV DS,AXMOV AX,0⑤JLE NEXT⑥JNZ NEXT⑦JNZ LOPA⑧BEGIN19.不相同,第一个数据段72H在前,04在后,后一个04H在前,72H在后。
钱晓捷新版汇编语言程序设计习题答案(修改)
![钱晓捷新版汇编语言程序设计习题答案(修改)](https://img.taocdn.com/s3/m/34772cd677eeaeaad1f34693daef5ef7ba0d12c1.png)
钱晓捷新版汇编语言程序设计习题答案第一章汇编语言基础知识1.1、简述计算机系统的硬件组成与各部分作用1.2、明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB1.3、什么是汇编语言源程序、汇编程序、目标程序?1.4、汇编语言与高级语言相比有什么优缺点?1.5、将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH1.6、将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕24581.7、将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕000000101.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕681.9、完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001〔5〕1011 ∧~1011 〔8〕1011 ⊕1001 1001〔6〕1011 ∨1001〔7〕1.10数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展.1.13、什么是DOS和ROM-BIOS?1.14、简述PC机最低1MB主存空间的使用情况.1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.1.17、举例说明CF和OF标志的差异.溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确•例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算: 58+124=182 ,X围外,有溢出•例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出1.18、字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?1.19、什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h1.20、8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令•堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据•数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据•附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据第二章8086指令系统2.1已知DS = 2000H、BX = 0100H、SI = 0002H,存储单元[20100H] ~ [20103H]依次存放12 34 56 78H,[21200H] ~ [21203H]依次存放2A 4C B7 65H,说明下列每条指令执行完后AX寄存器的内容.〔1〕 mov ax,1200h ;AX=1200h〔2〕 mov ax,bx ; AX=0100h〔3〕 mov ax,[1200h] ; AX=4C2Ah〔4〕 mov ax,[bx] ; AX=3412h〔5〕 mov ax,[bx+1100h] ;AX=4C2Ah〔6〕 mov ax,[bx+si] ; AX=7856h〔7〕 mov ax,[bx][si+1100h] ; AX=65B7h2.2指出下列指令的错误<1> mov cx,dl 两操作数类型不匹配<2> mov ip,ax IP指令指针禁止用户访问<3> mov es,1234h 立即数不允许传给段寄存器<4> mov es,ds段寄存器之间不允许传送<5> mov al,300 两操作数类型不匹配<6> mov [sp],ax目的操作数应为[ BP ]<7> mov ax,bx+di源操作数应为[BX+DI]<8> mov 20h,ah立即数不能作目的操作数2.3已知数字0 ~ 9对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址〔设为200H〕的连续区域中.请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果.lea bx,table ;获取table的首地址,BX=200Hmov al,8 ;传送欲转换的数字,AL=8xlat ;转换为格雷码,AL=12H2.4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?堆栈是一种按"先进后出〞原则存取数据的存储区域.堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP.2.5已知SS = FFA0H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?mov ax,8057hpush axmov ax,0f79hpush axpop bx ;bx=0f79hpop [bx] ;DS:[0f79h]=8057h2.6给出下列各条指令执行后AL值,以与CF、ZF、SF、OF和PF的状态:mov al,89h AL=89h CF ZF SF OF PFadd al,al AL=12h 1 0 0 1 1add al,9dh AL=0afh 0 0 1 0 1cmp al,0bch AL=0afh 1 0 1 0 1sub al,al AL=00h 0 1 0 0 1dec al AL=0ffh 0 0 1 0 1inc al AL=00h 0 1 0 0 12.7 设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;Z、Z+2的存储单元中,它们的运算结果存入W单元.阅读如下程序段,给出运算公式.mov ax,Xmov dx,X+2add ax,Yadc dx,Y+2add ax,24adc dx,0sub ax,Zsbb dx,Z+2mov W,axmov W+2,dxW=X+Y+24-Z2.8请分别用一条汇编语言指令完成如下功能:〔1〕把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器. ADD DX,BX〔2〕用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中.ADD AL,[BX+SI]〔3〕用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中.ADD [BX+0B2H],CX〔4〕用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中. ADD WORD PTR [0520H],3412H〔5〕把数0A0H与AL寄存器的内容相加,并把结果送回AL中.ADD AL,0A0H2.9;设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处.为了避免与操作数地址混淆,将题中X,Y,Z,V 字操作数改为A,B,C,Dmov ax,X ;ax=Aimul Y ;dx,ax = A*B <将操作数看作符号数,以下同〕mov cx,axmov bx,dx ;bx,ax <-- dx,ax =A*Bmov ax,Z ;ax = Ccwd ;dx,ax =C 〔扩展符号后为双字〕add cx,axadc bx,dx ;bx,cx <-- bx,cx+dx,ax=A*B+Csub cx,540sbb bx,0 ;bx,cx<-- A*B+C-540mov ax, V ;ax= Dcwd ;dx,ax= D 〔扩展符号后为双字〕sub ax, cxsbb dx, bx ;dx,ax = dx,ax - bx,cx = D-<A*B+C-540>idiv X ;运算结果:[D-<A*B+C-540h>]/A ;ax存商,dx存余数2.10;〔1〕xchg [si],30h xchg的操作数不能是立即数〔2〕pop cs不能对CS直接赋值〔3〕 sub [si],[di] 两个操作数不能都是存储单元〔4〕push ah堆栈的操作数不能是字节量〔5〕 adc ax,ds adc的操作数不能是段寄存器〔6〕 add [si],80h没有确定是字节还是字操作〔7〕 in al,3fch in不支持超过FFH的直接寻址〔8〕 out dx,ah out只能以AL/AX为源操作数2.11; 给出下列各条指令执行后的结果,以与状态标志CF、OF、SF、ZF、PF的状态. 指令 AX的值CF OF SF ZF PFMov ax,1470h 1470h - - - - -And ax,ax 1470h0 0 0 00Or ax,ax 1470h 0 0 0 0 0Xor ax,ax 0 0 0 0 1 1Not ax 0ffffh - - - - -Test ax,0f0f0h 0ffffh 0 0 1 0 1注意: 1. mov, not指令不影响标志位2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位.2.12; 假设例题2.32的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和注意:1. 左移N次相当于乘于2的N次方,右左移N次相当于除乘于2的N次方.2. 移位指令根据是否移入"1〞到CF,设置CF,根据移位后的结果影响SF,ZF,PF.根据最高符号位是否改变设置OF,如改变OF=1.3. ‘u ’表示无定义,‘- ’表示无影响.2.13编写程序段完成如下要求:<1> 用位操作指令实现AL〔无符号数〕乘以10;不考虑进位mov bl,almov cl,3shl al,cladd al,bl ;shl bl,1add al,bl;考虑进位xor ah,ahmov bx,axmov cl,3shl ax,cladd ax,bx ;shl bx,1add ax,bx<2> 用逻辑运算指令实现数字0 ~ 9的ASCII码与非压缩BCD码的互相转换数字0~9的ASCII码是:30h~39h非压缩BCD码的0~9是:00h~09h方法一:and al,0fh ;实现ASCII到非压缩BCD码的转换or al,30h ;实现非压缩BCD码到ASCII的转换方法二:xor al,30h ;求反D5D4位,其他不变;即高4位为3,则变为0;高4位为0,则变为3mov cl,4again: shr dx,1 ;实现逻辑右移;采用"sar dx,1〞,则实现算术右移rcr ax,1dec cljnz again<3> 把DX:.AX中的双字右移4位MOV CL, 4SHR AX, CLMOV BL, DLSHR DX, CLSHL BL, CLOR AH, BL2.14; 已知AL = F7H〔表示有符号数-9〕,分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?〔1〕用sar编写mov al,0f7h ;-9送alsar al,1 ;结果:al=0fbh 即-5〔2〕用idiv编写mov al,0f7h ;-9送alcbw ;字节符号扩展位字mov bl,2 ;注意除数不可为立即数idiv bl ;结果:商为al=fch <-4>;余数为ah=ffh <-1>结论:符号数的除法用idiv 准确2.15、已知数据段500h ~600h处存放了一个字符串,说明下列程序段执行后的结果:mov si,600hmov di,601hmov ax,dsmov es,axmov cx,256stdrep movsb2.16、说明下列程序段的功能cldmov ax,0fefhmov cx,5mov bx,3000hmov es,bxmov di,2000hrep stosw2.17、指令指针IP是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?调试程序DEBUG环境下,如何改变IP数值?2.18、控制转移类指令中有哪三种寻址方式?2.19;什么是短转移short jump、近转移near jump和远转移far jump?什么是段内转移和段间转移?8086有哪些指令可以实现段间转移?短转移:指段内-128~127之间的转移,位移量用一个字节表示近转移:指段内±32K之间的转移,位移量用一个字表示远转移:指段间1MB X围的转移段内转移:指在同一个代码段内的转移,可以是短转移或者近转移段间转移:指转移到另外一个代码段,就是远转移8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移2.20; 8086的条件转移指令的转移X围有多大?实际编程时,你如何处理超出X围的条件转移?8086的条件转移的转移X围:在当前指令地址的+127---- -128之内.如条件转移的转移X围超出此X围,可在此X围内安排一条无条件转移,再转移到X围外的目标地址.2.21; 假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?<1>JMP Bx ;转移的有效地址EA=BX=1256h<2>JMP tABLE[Bx] ;转移的有效地址EA=[ds:20a1h+1256h]=[232f7]=3280h<3>JMP [Bx][si] ;转移的有效地址EA=[ds:1256h+528fh]=264e5h=2450h2.22、判断下列程序段跳转的条件〔1〕 xor ax,1e1ehje equal;AX=1e1eh〔异或后为0〕〔2〕test al,10000001bjnz there;AL的D0或D7至少有一位为1〔3〕 cmp cx,64hthere;CX〔无符号数〕< 64h2.23; 设置CX = 0,则LOOP指令将循环多少次?例如mov cx,0 ;不循环,因为一进入循环就判cx=0? 如cx=0 就退出循环delay:loop delay循环次数是2的16次方,即2^16=65536.2.24 假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:〔1〕若DX > DI,转到above执行cmp dx,dija above ;=jnbe above〔2〕若AX > SI,转到greater执行cmp ax,sijg greater ;=jnle greater〔3〕若CX = 0,转到zero执行cmp cx,0 jcxz zerojz zero〔4〕若AX-SI产生溢出,转到overflow执行;cmp ax,dijo overflow〔5〕若SI≤AX,转到less_eq执行;cmp si,axcmp ax,sijle less_eqjge less_eq〔6〕若DI≤DX,转到below_eq执行.cmp di,dxcmp dx,die below_eqjae below_eq2.25有一个首地址为array的20个字的数组,说明下列程序段的功能.mov cx,20mov ax,0mov si,axsum_loop:add ax,array[si]add si,2loop sum_loopmov total,ax; 答:将首地址为array得20个字的数组求和,并将结果存入total 单元中.2.26 按照下列要求,编写相应的程序段:<1> 起始地址为string的主存单元中存放有一个字符串〔长度大于6〕,把该字符串中的第1个和第6个字符〔字节量〕传送给DX寄存器.mov si,0mov dl,string[si] ;第1个字符送dl寄存器mov si,5mov dh,string[si] ;第6个字符送dh寄存器<2> 从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低〔高〕地址对低〔高〕位的原则,将它们合并到DX中.xor si,si ;si清零mov al,buffer[si] ;第一字节inc simov ah,buffer[si] ;第二字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dl,al ;存入dl寄..inc simov al,buffer[si] ;第三字节inc simov ah,buffer[si] ;第四字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dh,al ;存入dh寄..<3> 编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1.test dx,0f000hjz zeromov ax,-1jmp donezero: mov ax,0done: ret<4> 有两个64位数值,按"小端方式〞存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1-buffer2功能.lea bx,buffer1lea dx,buffer2mov cx,8 ;8个字节xor si,si ;si=0clc ;CF=0<5> 假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中.mov ax,0b800hmov ds,ax ;段地址xor si,si ;地址偏移量si=0xor dx,dx ;和的高字dx=0mov cx,99 ;加的次数mov ax,[si] ;第一个数again: inc si ;指向下一个字单元inc siadd ax,[si] ;加下一个数jnc noc ;无进位转inc dx ;有进位dx=dx+1noc: dec cx ;次数-1jnz cx,again ;非0继续加ret<6> 已知字符串string包含有32KB内容,将其中的’$’符号替换成空格.mov si,offset stringmov cx,8000h ;32k=2^15=8000hagain: cmp [si],’$’jnz nextmov [si],20h ;if [si]=’$’[si]<-- ’’next: inc siloop again<7> 有一个100个字节元素的数组,其首地址为array,将每个元素减1〔不考虑溢出〕存于原处.xor si,si ;si<--0mov cx,100 ;循环次数again: dec array[si]dec cxjnz again<8> 统计以’$’结尾的字符串srting的字符个数.xor si,si ;si<--0coun: cmp string[si],’$’je doneinc sijmp coundone: ret2.27; 对下面要求,分别给出3种方法,每种方法只用一条指令.<1>使CF=0 :clc ;and ax,ax ;or ax,ax<2>使AX=0 :xor ax,ax ;and ax,0 ;mov ax,0<3>同时使AX=0和CF=0:and ax,0 ;xor ax,ax ;sub ax,ax2.28、参照本习题的示意图,分析调用序列,画出每次调用与返回时的堆栈状态.其中CALL前是该指令所在的逻辑地址;另外,段内直接调用指令的机器代码的字节数为3,段间直接调用指令则为5个字节.2.29已知AX 、BX存放的是4位压缩BCD表示的十进制数,请说明如下子程序的功能和出口参数.add al,bldaaxchg al,ahadc al,bhdaaxchg al,ahret压缩BCD码加法:AX←AX+BX出口参数:AX=BCD码和2.30、AAD指令是用于除法指令之前,进行非压缩BCD码调整的.实际上,处理器的调整过程是:AL←AH×10+AL,AH←0.如果指令系统没有AAD指令,请用一个子程序完成这个调整工作.2.31、解释如下有关中断的概念:〔1〕内部中断和外部中断〔2〕单步中断和断点中断〔3〕除法错中断和溢出中断〔4〕中断向量号和中断向量表2.32、试比较INT n和段间CALL指令、IRET和段间RET指令的功能.2.33、什么是系统功能调用?汇编语言中,它的一般格式是怎样的?2.34; 补充例2.38,当有溢出时显示"Error! Overflow!〞,无溢出时显示"OK〞.okmsg db ‘OK’,‘$’errmsg db ‘Error! Overflow !’,‘$’…mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgjmp nextoverflow: mov dx,errmsgnext: mov ah,9int 21h错误:mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgokmsg db ‘OK’,‘$’mov dx,errmsg ;错误1:数据定义在代码中mov ah,9int 21hoverflow: errmsg db ‘Error! Overflow !’,‘$’mov dx,errmsg ; 错误2:缺少JMP指令mov ah,9int 21h2.35、补充例2.39,显示"1〞的个数;注意首先将个数转换为ASCII码.2.36、先提示输入数字"Input Number:0 ~ 9〞,然后在下一行显示输入的数字,结束;如果不是键入了0 ~ 9数字,就提示错误"Error!〞,继续等待输入数字.2.37 从键盘输入一个字符串〔不超过255个〕,将其中的小写字母转换成大写字母,然后按原来的顺序在屏幕上显示.;xt237.asm.model small.stack.dataarray db 255db 0array1 db 255 dup<'$'>array2 db 0dh,0ah,'$'.code.startupmov ah,0ah ; 键盘输入字符串mov dx,offset arrayint 21hmov dx,offset array2 ; 回车换行mov ah,09hint 21hmov bx,offset array1again: mov al,[bx]cmp al,'$'jz donecmp al,'a' ; 小于a和大于z的字符不是小写字母nextcmp al,'z'ja nextsub al,20h ; 在a和z之间的字符才是小写字母,转换为大写mov [bx],al ; 保存到原位置next: inc bxjmp againdone: mov dx,offset array1mov ah,09hint 21h.exit 0end2.38、指令对状态标志的作用可以分成多种情况,例如无影响、无定义、按结果影响、特别说明的影响等,你能区别这些情况吗?分别用具体的指令来说明.2.39、8086指令系统分成哪6个功能组?各组主要包含什么指令,举例说明.2.40、总结8086指令系统所采用的各种寻址方式,包括一般的数据寻址、外设数据寻址、堆栈数据寻址、串操作数据寻址、转移指令目的地址的寻址等,并举例说明.另外找的!第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成与各部分作用.〔解答〕CPU:包括运算器、控制器和寄存器组.运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据.存储器:是计算机的记忆部件,它用来存放程序以与程序中所涉与的数据.外部设备:实现人机交换和机间的通信.〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快.辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢.RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息.存储器由大量存储单元组成.为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口.KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位.〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序.〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在"时间〞和"空间〞两方面最有效的程序.汇编语言与高级语言相比的缺点:由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,又涉与寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标程序往往比较庞大、程序难以优化,运行速度慢.〔习题1.5〕将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH〔解答〕〔1〕FFH 11111111B 255D〔2〕0H 0B 0D〔3〕5EH 1011110B 94D〔4〕EFH 11101111B 239D〔5〕2EH 101110B 46D〔6〕10H 10000B 16D〔7〕1FH 11111B 31D〔8〕ABH 10101011B 171D〔习题1.6〕将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕2458〔解答〕〔1〕12 00010010〔2〕24 00100100〔3〕68 01101000〔4〕127 000100100111〔5〕128 000100101000〔6〕255 001001010101〔习题1.7〕将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕00000010〔解答〕〔1〕91〔2〕89〔3〕36〔4〕90〔5〕08〔6〕97〔7〕81〔8〕02〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕68〔解答〕〔1〕0 +0 00000000 00000000 00000000-0 10000000 11111111 00000000〔2〕-127 11111111 10000000 10000001〔3〕127 01111111 01111111 01111111〔4〕-57 10101111 11010000 11010001〔5〕126 01111110 01111110 01111110〔6〕-126 11111110 10000001 10000010〔7〕-128 10000000〔8〕68 01000100 01000100 01000100〔习题1.9〕完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001 〔5〕1011 ∧1001 〔6〕1011 ∨1001 〔7〕~1011 〔8〕1011 ? 1001 〔解答〕〔1〕1011+1001=10100〔2〕1011-1001=0010〔3〕1011×1001=1100011〔4〕10111000÷1001=10100,余数1000〔5〕1011 ∧1001=1001〔6〕1011 ∨1001=1011〔7〕~1011=0100<8> 1011?1001=0010<?代表异或>〔习题1.10〕数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?〔解答〕数码0~9:30H~39H大写字母A~Z:41H~5AH小写字母a~z:61H~7AHASCII码为0dh、0ah分别对应回车和换行控制字符.〔习题1.11〕计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是十进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?〔解答〕十进制无符号数:01100001B=61H=97BCD码:61ASCII码:a〔习题1.12〕简述Intel 80x86系列微处理器在指令集方面的发展.〔解答〕1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel 推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉与堆栈操作、移位指令、过程指令和边界检测与乘法指令,1982年Intel推出80286 CPU, 80286指令系统包括全部80186指令与新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386 CPU, 80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以与控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium.Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以与4条系统专用指令,1996年推出了MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,20##推出的Pentium4新增了76条SSE2指令〔习题1.13〕什么是DOS和ROM-BIOS?〔解答〕DOS是Diskette Operating system的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层"外壳〞,是1981~1995年的个人电脑上使用的一种主要的操作系统.BIOS〔Basic Input/Output System〕即基本输入输出系统,通常是固化在只读存储器〔ROM〕中,所以又称为ROM-BIOS.它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽.ROM-BIOS是计算机系统中用来提供最低级、最直接的硬件控制的程序.〔习题1.14〕简述PC机最低1MB主存空间的使用情况.〔解答〕〔1〕基本RAM区<00000H—9FFFFH>该区共640KB,由DOS进行管理.在这个区域中操作系统要占用掉一部分低地址空间,其它则向用户程序开放.〔2〕保留区RAM〔A0000H--BFFFFFH〕该区为系统安排的"显示缓冲存储区〞,共126KB,是显卡上的芯片提供支持,用于存放屏幕显示信息.但这部分地址空间实际上并没有全部使用.〔3〕扩展区ROM〔C0000H--DFFFFH〕该区128KB,由接口卡上的芯片提供支持,用于为系统不直接支持的外设安排设备驱动程序.用户固化的程序就可[安排在这一段,系统的会对它进行确认和连接.〔4〕系统区ROM〔E0000H--FFFFFH〕该区共128KB,由系统占用,它主要提供ROM--BIOS 程序,基本输入输出程序BIOS,是操作系统的重要组成部分,主要用来驱动输入输出设备,也负责系统的上电检测,磁盘引导等初始化操作,在ROM--BIOS中还有CMOS微机设置程序以与使用的字符图符信息等内容.〔习题1.15〕罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.〔解答〕〔1〕数据寄存器:AX称为累加器,使用频度最高,用于算术、逻辑运算以与与外设传送信息等;BX称为基址寄存器,常用做存放存储器地址;CX称为计数器,作为循环和串操作等指令中的隐含计数器;DX称为数据寄存器,常用来存放双字长数据的高16位,或存放外设端口地址.〔2〕指针与变址寄存器包括SI,DI,BP,S P,四个寄存器,常用于存储器寻址时提供地址.SI是源变址寄存器,DI是目的变址寄存器,一般与DS联用确定数据段和附加段中某一存储单元地址,在串指令中,SI与DS联用、DI和ES联用,分别寻址数据段和附加段;同时,在串指令中,SI和DI还都具有自动增量或减量的功能.S P,为堆栈指针寄存器,指示栈顶的偏移地址;BP为基地址指针寄存器,表示堆栈段中的基地址.S P与BP寄存器均可与SS段寄存器联合使用以确定堆栈段中的存储单元地址.〔习题1.16〕什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.〔解答〕标志用于反映指令执行结果或控制指令执行形式.它是汇编语言程序设计中必须特别注意的一个方面,状态用来记录运行的结果的状态信息,许多指令的执行都将相应地设置它,控制标志位可由程序根据需要用指令设置,用来控制处理器执行指令的方式.CF是进位标志;ZF 是零标志;SF是符号标志;PF奇偶标志;OF溢出标志;AF辅助进位标志;DF方向标志;IF中断允许标志;TF陷阱标志.〔习题1.17〕举例说明CF和OF标志的差异.〔解答〕溢出标志OF和进位标志CF是两个意义不同的标志.进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确.例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算:58+124=182 ,X围外,有溢出例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出〔习题1.18〕字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?〔解答〕字或双字在存储器中占相邻的2个或4个存储单元;存放时,低字节存入低地址,高字节存入高地址;字或双字单元的地址用它的低地址来表示.80x86处理器采用的这种"低对低,高对高〞的存储形式,被称为"小端方式〞;将字单元安排在偶地址,双字节单元安排在模4地址,被称为"地址对齐方式〞因为对于不对齐地址的数据,处理器访问时,需要额外的访问时间,所以通常应该将数据的地址对齐,以取得较高的存取速度.〔习题1.19〕什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h〔解答〕在8086处理器中,对应每个物理存储单元都有一个唯一的20位编号,就是物理地址,从00000H~FFFFFH.在8086内部和用户编程时,采用的段基地址: 段内偏移地址形式称为逻辑地址.将逻辑地址中的段地址左移二进制4位〔对应16进制是一位,即乘以16〕,加上偏移地址就得到20位物理地址如下逻辑地址用物理地址表达:〔1〕FFFFh:0=FFFF0H〔2〕40h:17h=00417H〔3〕2000h:4500h=24500H〔4〕B821h:4567h=BC777H 〔不要算错〕〔习题1.20〕8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令.堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据.数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据.附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据〔习题1.21〕数据的默认段是哪个,是否允许其他段存放数据?如果允许,如何实现,有什么要求?〔解答〕数据的默认段是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段,允许其它段存放数据,数据的存放比较灵活的,实际上可以存放在任何一种逻辑段中,这时,只要明确指明是哪个逻辑段就可以了.〔习题1.22〕什么是操作码、操作数和寻址方式?有哪三种给出操作数的方法?〔解答〕操作码说明计算机要执行哪种操作,它是指令中不可缺少的组成部分,操作数是指令执行的参与者,也是各种操作的对象,我们把寻找数的方式叫做操作数的寻址方式.给出操作数的三种方法是直接给出,间接给出,隐藏操作数方式给出.〔习题1.23〕什么是有效地址EA?8086的操作数如果在主存中,有哪些寻址方式可以存取它?〔解答〕。
钱晓捷-汇编语言程序设计课后习题(作业新)
![钱晓捷-汇编语言程序设计课后习题(作业新)](https://img.taocdn.com/s3/m/b80eb99476eeaeaad0f3303f.png)
习题1 (1)习题2 (4)习题3 (10)习题4 (13)习题5 (15)习题6 (18)习题7 (21)习题8 (24)习题9 (27)1.1 简述计算机系统的硬件组成及各部分作用。
1.2 明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB,MB,GB和TB。
1.3 什么是汇编语言源程序、汇编程序、目标程序?1.4 汇编语言与高级语言相比有什么优缺点?1.5 将下列十六进制转化为二进制和十进制表示。
(1)FFH (2)0H (3)5EH (4)EFH(5)2EH (6)10H (7)1FH (8)ABH1.6 将下列十进制数转换为BCD码表示。
(1)12 (2)24 (3)68 (4)127(5)128 (6)255 (7)1234 (8)2458解答:十进制数 BCD码122468127 11280255 11234101002458 110001.7 将下列BCD码转换为十进制数。
(1)10010001 (2)10001001 (3)00110110 (4)10010000(5)00001000 (6)10010111 (7)10000001 (8)00000010解答:BCD码十进制数10010001 9110001001 8900110110 3610010000 9000001000 0810010111 9710000001 8100000010 021.8 将下列十进制数分别用八位二进制数的原码、反码和补码表示。
(1)0 (2)-127 (3)127 (4)-57 (5)126 (6)-126 (7)-128(8)681.9 完成下列二进制数的计算。
(1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000/1001(5)1011∧1001 (6)1011∨1001 (7)~1011 (8)1011⊕10011.10 数码0~9,大写字母A~Z,小写字母a~z,对应的ASCII码分别是多少?ASCII码为0dH,0aH对应的是什么字符?解答:大写字母A~Z,对应的ASCII码分别是41H~5AH小写字母a~z,对应的ASCII码分别是61H~7AHASCII码为0dH,0aH分别对应“回车”、“换行”1.11 计算机中有一个“”编码,如果把它认为是无符号数,它是十进制什么数?如果你认为它是BCD码,则表示什么数?如果它是某个ASCII码,则代表哪个字符?1.12 简述Intel80x86系列微处理器在指令集方面的发展。
32位汇编习题04
![32位汇编习题04](https://img.taocdn.com/s3/m/7b1728c80975f46527d3e1a2.png)
;输入N,小于10 ;EAX=地址 ;显示地址 ;EAX=变量值 ;显示数值
习题解答
习题4.15-1
• IA-32 处理器的指令 CDQ 将 EAX 符号扩展到 EDX 。假若
没有该指令,编程实现该指令功能。 (1)按照符号扩展的含义编程,即:EAX最高为0,则 EDX=0;EAX最高为1,则EDX=FFFFFFFFH。 test eax,8000h ;测试最高位 jz next1 ;最高位为0,转移 mov edx,0ffffffffh ;最高位为1,设置EDX=FFFFFFFFH jmp done ;跳过另一个分支 next1: mov dx,0 ;设置EDX=0 done:
4
习题解答
4.2 判断题
2)指令的相对寻址都是近转移。 •对 4)JMP指令对应高级语言的GOTO语句,所以不能使用 • 错,需要使用 6)JA和JG指令的条件都是“大于”,所以是同一个指 令的两个助记符。 • 错,JA针对无符号数,JG针对有符号数 7)JC和JB的条件都是CF=1,所以是同一条指令。 • 对。无符号小于(JB)必然借位(JC) 10)若ECX=0,则LOOP指令和JECX指令都发生转移。 •对
5
习题解答
4.3 填空题-1
(2)MASM 给短转移、近转移和远转移定义的类型名依 次是___、___和___。 • SHORT,NEAR,FAR (3)假设在平展存储模型下,EBX=1256H,双字变量 TABLE 的偏移地址是 20A1H ,线性地址 32F7H 处存 放 3280H ,执行指令“ JMP EBX” 后 EIP = _______ ,执 行指令“JMP TABLE[EBX]”后EIP=_______。 • 1256H,3280H
钱晓捷新版汇编语言程序设计习题答案(修改)
![钱晓捷新版汇编语言程序设计习题答案(修改)](https://img.taocdn.com/s3/m/34772cd677eeaeaad1f34693daef5ef7ba0d12c1.png)
钱晓捷新版汇编语言程序设计习题答案第一章汇编语言基础知识1.1、简述计算机系统的硬件组成与各部分作用1.2、明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB1.3、什么是汇编语言源程序、汇编程序、目标程序?1.4、汇编语言与高级语言相比有什么优缺点?1.5、将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH1.6、将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕24581.7、将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕000000101.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕681.9、完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001〔5〕1011 ∧~1011 〔8〕1011 ⊕1001 1001〔6〕1011 ∨1001〔7〕1.10数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展.1.13、什么是DOS和ROM-BIOS?1.14、简述PC机最低1MB主存空间的使用情况.1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.1.17、举例说明CF和OF标志的差异.溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确•例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算: 58+124=182 ,X围外,有溢出•例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出1.18、字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?1.19、什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h1.20、8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令•堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据•数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据•附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据第二章8086指令系统2.1已知DS = 2000H、BX = 0100H、SI = 0002H,存储单元[20100H] ~ [20103H]依次存放12 34 56 78H,[21200H] ~ [21203H]依次存放2A 4C B7 65H,说明下列每条指令执行完后AX寄存器的内容.〔1〕 mov ax,1200h ;AX=1200h〔2〕 mov ax,bx ; AX=0100h〔3〕 mov ax,[1200h] ; AX=4C2Ah〔4〕 mov ax,[bx] ; AX=3412h〔5〕 mov ax,[bx+1100h] ;AX=4C2Ah〔6〕 mov ax,[bx+si] ; AX=7856h〔7〕 mov ax,[bx][si+1100h] ; AX=65B7h2.2指出下列指令的错误<1> mov cx,dl 两操作数类型不匹配<2> mov ip,ax IP指令指针禁止用户访问<3> mov es,1234h 立即数不允许传给段寄存器<4> mov es,ds段寄存器之间不允许传送<5> mov al,300 两操作数类型不匹配<6> mov [sp],ax目的操作数应为[ BP ]<7> mov ax,bx+di源操作数应为[BX+DI]<8> mov 20h,ah立即数不能作目的操作数2.3已知数字0 ~ 9对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址〔设为200H〕的连续区域中.请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果.lea bx,table ;获取table的首地址,BX=200Hmov al,8 ;传送欲转换的数字,AL=8xlat ;转换为格雷码,AL=12H2.4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?堆栈是一种按"先进后出〞原则存取数据的存储区域.堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP.2.5已知SS = FFA0H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?mov ax,8057hpush axmov ax,0f79hpush axpop bx ;bx=0f79hpop [bx] ;DS:[0f79h]=8057h2.6给出下列各条指令执行后AL值,以与CF、ZF、SF、OF和PF的状态:mov al,89h AL=89h CF ZF SF OF PFadd al,al AL=12h 1 0 0 1 1add al,9dh AL=0afh 0 0 1 0 1cmp al,0bch AL=0afh 1 0 1 0 1sub al,al AL=00h 0 1 0 0 1dec al AL=0ffh 0 0 1 0 1inc al AL=00h 0 1 0 0 12.7 设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;Z、Z+2的存储单元中,它们的运算结果存入W单元.阅读如下程序段,给出运算公式.mov ax,Xmov dx,X+2add ax,Yadc dx,Y+2add ax,24adc dx,0sub ax,Zsbb dx,Z+2mov W,axmov W+2,dxW=X+Y+24-Z2.8请分别用一条汇编语言指令完成如下功能:〔1〕把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器. ADD DX,BX〔2〕用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中.ADD AL,[BX+SI]〔3〕用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中.ADD [BX+0B2H],CX〔4〕用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中. ADD WORD PTR [0520H],3412H〔5〕把数0A0H与AL寄存器的内容相加,并把结果送回AL中.ADD AL,0A0H2.9;设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处.为了避免与操作数地址混淆,将题中X,Y,Z,V 字操作数改为A,B,C,Dmov ax,X ;ax=Aimul Y ;dx,ax = A*B <将操作数看作符号数,以下同〕mov cx,axmov bx,dx ;bx,ax <-- dx,ax =A*Bmov ax,Z ;ax = Ccwd ;dx,ax =C 〔扩展符号后为双字〕add cx,axadc bx,dx ;bx,cx <-- bx,cx+dx,ax=A*B+Csub cx,540sbb bx,0 ;bx,cx<-- A*B+C-540mov ax, V ;ax= Dcwd ;dx,ax= D 〔扩展符号后为双字〕sub ax, cxsbb dx, bx ;dx,ax = dx,ax - bx,cx = D-<A*B+C-540>idiv X ;运算结果:[D-<A*B+C-540h>]/A ;ax存商,dx存余数2.10;〔1〕xchg [si],30h xchg的操作数不能是立即数〔2〕pop cs不能对CS直接赋值〔3〕 sub [si],[di] 两个操作数不能都是存储单元〔4〕push ah堆栈的操作数不能是字节量〔5〕 adc ax,ds adc的操作数不能是段寄存器〔6〕 add [si],80h没有确定是字节还是字操作〔7〕 in al,3fch in不支持超过FFH的直接寻址〔8〕 out dx,ah out只能以AL/AX为源操作数2.11; 给出下列各条指令执行后的结果,以与状态标志CF、OF、SF、ZF、PF的状态. 指令 AX的值CF OF SF ZF PFMov ax,1470h 1470h - - - - -And ax,ax 1470h0 0 0 00Or ax,ax 1470h 0 0 0 0 0Xor ax,ax 0 0 0 0 1 1Not ax 0ffffh - - - - -Test ax,0f0f0h 0ffffh 0 0 1 0 1注意: 1. mov, not指令不影响标志位2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位.2.12; 假设例题2.32的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和注意:1. 左移N次相当于乘于2的N次方,右左移N次相当于除乘于2的N次方.2. 移位指令根据是否移入"1〞到CF,设置CF,根据移位后的结果影响SF,ZF,PF.根据最高符号位是否改变设置OF,如改变OF=1.3. ‘u ’表示无定义,‘- ’表示无影响.2.13编写程序段完成如下要求:<1> 用位操作指令实现AL〔无符号数〕乘以10;不考虑进位mov bl,almov cl,3shl al,cladd al,bl ;shl bl,1add al,bl;考虑进位xor ah,ahmov bx,axmov cl,3shl ax,cladd ax,bx ;shl bx,1add ax,bx<2> 用逻辑运算指令实现数字0 ~ 9的ASCII码与非压缩BCD码的互相转换数字0~9的ASCII码是:30h~39h非压缩BCD码的0~9是:00h~09h方法一:and al,0fh ;实现ASCII到非压缩BCD码的转换or al,30h ;实现非压缩BCD码到ASCII的转换方法二:xor al,30h ;求反D5D4位,其他不变;即高4位为3,则变为0;高4位为0,则变为3mov cl,4again: shr dx,1 ;实现逻辑右移;采用"sar dx,1〞,则实现算术右移rcr ax,1dec cljnz again<3> 把DX:.AX中的双字右移4位MOV CL, 4SHR AX, CLMOV BL, DLSHR DX, CLSHL BL, CLOR AH, BL2.14; 已知AL = F7H〔表示有符号数-9〕,分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?〔1〕用sar编写mov al,0f7h ;-9送alsar al,1 ;结果:al=0fbh 即-5〔2〕用idiv编写mov al,0f7h ;-9送alcbw ;字节符号扩展位字mov bl,2 ;注意除数不可为立即数idiv bl ;结果:商为al=fch <-4>;余数为ah=ffh <-1>结论:符号数的除法用idiv 准确2.15、已知数据段500h ~600h处存放了一个字符串,说明下列程序段执行后的结果:mov si,600hmov di,601hmov ax,dsmov es,axmov cx,256stdrep movsb2.16、说明下列程序段的功能cldmov ax,0fefhmov cx,5mov bx,3000hmov es,bxmov di,2000hrep stosw2.17、指令指针IP是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?调试程序DEBUG环境下,如何改变IP数值?2.18、控制转移类指令中有哪三种寻址方式?2.19;什么是短转移short jump、近转移near jump和远转移far jump?什么是段内转移和段间转移?8086有哪些指令可以实现段间转移?短转移:指段内-128~127之间的转移,位移量用一个字节表示近转移:指段内±32K之间的转移,位移量用一个字表示远转移:指段间1MB X围的转移段内转移:指在同一个代码段内的转移,可以是短转移或者近转移段间转移:指转移到另外一个代码段,就是远转移8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移2.20; 8086的条件转移指令的转移X围有多大?实际编程时,你如何处理超出X围的条件转移?8086的条件转移的转移X围:在当前指令地址的+127---- -128之内.如条件转移的转移X围超出此X围,可在此X围内安排一条无条件转移,再转移到X围外的目标地址.2.21; 假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?<1>JMP Bx ;转移的有效地址EA=BX=1256h<2>JMP tABLE[Bx] ;转移的有效地址EA=[ds:20a1h+1256h]=[232f7]=3280h<3>JMP [Bx][si] ;转移的有效地址EA=[ds:1256h+528fh]=264e5h=2450h2.22、判断下列程序段跳转的条件〔1〕 xor ax,1e1ehje equal;AX=1e1eh〔异或后为0〕〔2〕test al,10000001bjnz there;AL的D0或D7至少有一位为1〔3〕 cmp cx,64hthere;CX〔无符号数〕< 64h2.23; 设置CX = 0,则LOOP指令将循环多少次?例如mov cx,0 ;不循环,因为一进入循环就判cx=0? 如cx=0 就退出循环delay:loop delay循环次数是2的16次方,即2^16=65536.2.24 假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:〔1〕若DX > DI,转到above执行cmp dx,dija above ;=jnbe above〔2〕若AX > SI,转到greater执行cmp ax,sijg greater ;=jnle greater〔3〕若CX = 0,转到zero执行cmp cx,0 jcxz zerojz zero〔4〕若AX-SI产生溢出,转到overflow执行;cmp ax,dijo overflow〔5〕若SI≤AX,转到less_eq执行;cmp si,axcmp ax,sijle less_eqjge less_eq〔6〕若DI≤DX,转到below_eq执行.cmp di,dxcmp dx,die below_eqjae below_eq2.25有一个首地址为array的20个字的数组,说明下列程序段的功能.mov cx,20mov ax,0mov si,axsum_loop:add ax,array[si]add si,2loop sum_loopmov total,ax; 答:将首地址为array得20个字的数组求和,并将结果存入total 单元中.2.26 按照下列要求,编写相应的程序段:<1> 起始地址为string的主存单元中存放有一个字符串〔长度大于6〕,把该字符串中的第1个和第6个字符〔字节量〕传送给DX寄存器.mov si,0mov dl,string[si] ;第1个字符送dl寄存器mov si,5mov dh,string[si] ;第6个字符送dh寄存器<2> 从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低〔高〕地址对低〔高〕位的原则,将它们合并到DX中.xor si,si ;si清零mov al,buffer[si] ;第一字节inc simov ah,buffer[si] ;第二字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dl,al ;存入dl寄..inc simov al,buffer[si] ;第三字节inc simov ah,buffer[si] ;第四字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dh,al ;存入dh寄..<3> 编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1.test dx,0f000hjz zeromov ax,-1jmp donezero: mov ax,0done: ret<4> 有两个64位数值,按"小端方式〞存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1-buffer2功能.lea bx,buffer1lea dx,buffer2mov cx,8 ;8个字节xor si,si ;si=0clc ;CF=0<5> 假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中.mov ax,0b800hmov ds,ax ;段地址xor si,si ;地址偏移量si=0xor dx,dx ;和的高字dx=0mov cx,99 ;加的次数mov ax,[si] ;第一个数again: inc si ;指向下一个字单元inc siadd ax,[si] ;加下一个数jnc noc ;无进位转inc dx ;有进位dx=dx+1noc: dec cx ;次数-1jnz cx,again ;非0继续加ret<6> 已知字符串string包含有32KB内容,将其中的’$’符号替换成空格.mov si,offset stringmov cx,8000h ;32k=2^15=8000hagain: cmp [si],’$’jnz nextmov [si],20h ;if [si]=’$’[si]<-- ’’next: inc siloop again<7> 有一个100个字节元素的数组,其首地址为array,将每个元素减1〔不考虑溢出〕存于原处.xor si,si ;si<--0mov cx,100 ;循环次数again: dec array[si]dec cxjnz again<8> 统计以’$’结尾的字符串srting的字符个数.xor si,si ;si<--0coun: cmp string[si],’$’je doneinc sijmp coundone: ret2.27; 对下面要求,分别给出3种方法,每种方法只用一条指令.<1>使CF=0 :clc ;and ax,ax ;or ax,ax<2>使AX=0 :xor ax,ax ;and ax,0 ;mov ax,0<3>同时使AX=0和CF=0:and ax,0 ;xor ax,ax ;sub ax,ax2.28、参照本习题的示意图,分析调用序列,画出每次调用与返回时的堆栈状态.其中CALL前是该指令所在的逻辑地址;另外,段内直接调用指令的机器代码的字节数为3,段间直接调用指令则为5个字节.2.29已知AX 、BX存放的是4位压缩BCD表示的十进制数,请说明如下子程序的功能和出口参数.add al,bldaaxchg al,ahadc al,bhdaaxchg al,ahret压缩BCD码加法:AX←AX+BX出口参数:AX=BCD码和2.30、AAD指令是用于除法指令之前,进行非压缩BCD码调整的.实际上,处理器的调整过程是:AL←AH×10+AL,AH←0.如果指令系统没有AAD指令,请用一个子程序完成这个调整工作.2.31、解释如下有关中断的概念:〔1〕内部中断和外部中断〔2〕单步中断和断点中断〔3〕除法错中断和溢出中断〔4〕中断向量号和中断向量表2.32、试比较INT n和段间CALL指令、IRET和段间RET指令的功能.2.33、什么是系统功能调用?汇编语言中,它的一般格式是怎样的?2.34; 补充例2.38,当有溢出时显示"Error! Overflow!〞,无溢出时显示"OK〞.okmsg db ‘OK’,‘$’errmsg db ‘Error! Overflow !’,‘$’…mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgjmp nextoverflow: mov dx,errmsgnext: mov ah,9int 21h错误:mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgokmsg db ‘OK’,‘$’mov dx,errmsg ;错误1:数据定义在代码中mov ah,9int 21hoverflow: errmsg db ‘Error! Overflow !’,‘$’mov dx,errmsg ; 错误2:缺少JMP指令mov ah,9int 21h2.35、补充例2.39,显示"1〞的个数;注意首先将个数转换为ASCII码.2.36、先提示输入数字"Input Number:0 ~ 9〞,然后在下一行显示输入的数字,结束;如果不是键入了0 ~ 9数字,就提示错误"Error!〞,继续等待输入数字.2.37 从键盘输入一个字符串〔不超过255个〕,将其中的小写字母转换成大写字母,然后按原来的顺序在屏幕上显示.;xt237.asm.model small.stack.dataarray db 255db 0array1 db 255 dup<'$'>array2 db 0dh,0ah,'$'.code.startupmov ah,0ah ; 键盘输入字符串mov dx,offset arrayint 21hmov dx,offset array2 ; 回车换行mov ah,09hint 21hmov bx,offset array1again: mov al,[bx]cmp al,'$'jz donecmp al,'a' ; 小于a和大于z的字符不是小写字母nextcmp al,'z'ja nextsub al,20h ; 在a和z之间的字符才是小写字母,转换为大写mov [bx],al ; 保存到原位置next: inc bxjmp againdone: mov dx,offset array1mov ah,09hint 21h.exit 0end2.38、指令对状态标志的作用可以分成多种情况,例如无影响、无定义、按结果影响、特别说明的影响等,你能区别这些情况吗?分别用具体的指令来说明.2.39、8086指令系统分成哪6个功能组?各组主要包含什么指令,举例说明.2.40、总结8086指令系统所采用的各种寻址方式,包括一般的数据寻址、外设数据寻址、堆栈数据寻址、串操作数据寻址、转移指令目的地址的寻址等,并举例说明.另外找的!第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成与各部分作用.〔解答〕CPU:包括运算器、控制器和寄存器组.运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据.存储器:是计算机的记忆部件,它用来存放程序以与程序中所涉与的数据.外部设备:实现人机交换和机间的通信.〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快.辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢.RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息.存储器由大量存储单元组成.为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口.KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位.〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序.〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在"时间〞和"空间〞两方面最有效的程序.汇编语言与高级语言相比的缺点:由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,又涉与寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标程序往往比较庞大、程序难以优化,运行速度慢.〔习题1.5〕将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH〔解答〕〔1〕FFH 11111111B 255D〔2〕0H 0B 0D〔3〕5EH 1011110B 94D〔4〕EFH 11101111B 239D〔5〕2EH 101110B 46D〔6〕10H 10000B 16D〔7〕1FH 11111B 31D〔8〕ABH 10101011B 171D〔习题1.6〕将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕2458〔解答〕〔1〕12 00010010〔2〕24 00100100〔3〕68 01101000〔4〕127 000100100111〔5〕128 000100101000〔6〕255 001001010101〔习题1.7〕将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕00000010〔解答〕〔1〕91〔2〕89〔3〕36〔4〕90〔5〕08〔6〕97〔7〕81〔8〕02〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕68〔解答〕〔1〕0 +0 00000000 00000000 00000000-0 10000000 11111111 00000000〔2〕-127 11111111 10000000 10000001〔3〕127 01111111 01111111 01111111〔4〕-57 10101111 11010000 11010001〔5〕126 01111110 01111110 01111110〔6〕-126 11111110 10000001 10000010〔7〕-128 10000000〔8〕68 01000100 01000100 01000100〔习题1.9〕完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001 〔5〕1011 ∧1001 〔6〕1011 ∨1001 〔7〕~1011 〔8〕1011 ? 1001 〔解答〕〔1〕1011+1001=10100〔2〕1011-1001=0010〔3〕1011×1001=1100011〔4〕10111000÷1001=10100,余数1000〔5〕1011 ∧1001=1001〔6〕1011 ∨1001=1011〔7〕~1011=0100<8> 1011?1001=0010<?代表异或>〔习题1.10〕数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?〔解答〕数码0~9:30H~39H大写字母A~Z:41H~5AH小写字母a~z:61H~7AHASCII码为0dh、0ah分别对应回车和换行控制字符.〔习题1.11〕计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是十进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?〔解答〕十进制无符号数:01100001B=61H=97BCD码:61ASCII码:a〔习题1.12〕简述Intel 80x86系列微处理器在指令集方面的发展.〔解答〕1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel 推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉与堆栈操作、移位指令、过程指令和边界检测与乘法指令,1982年Intel推出80286 CPU, 80286指令系统包括全部80186指令与新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386 CPU, 80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以与控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium.Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以与4条系统专用指令,1996年推出了MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,20##推出的Pentium4新增了76条SSE2指令〔习题1.13〕什么是DOS和ROM-BIOS?〔解答〕DOS是Diskette Operating system的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层"外壳〞,是1981~1995年的个人电脑上使用的一种主要的操作系统.BIOS〔Basic Input/Output System〕即基本输入输出系统,通常是固化在只读存储器〔ROM〕中,所以又称为ROM-BIOS.它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽.ROM-BIOS是计算机系统中用来提供最低级、最直接的硬件控制的程序.〔习题1.14〕简述PC机最低1MB主存空间的使用情况.〔解答〕〔1〕基本RAM区<00000H—9FFFFH>该区共640KB,由DOS进行管理.在这个区域中操作系统要占用掉一部分低地址空间,其它则向用户程序开放.〔2〕保留区RAM〔A0000H--BFFFFFH〕该区为系统安排的"显示缓冲存储区〞,共126KB,是显卡上的芯片提供支持,用于存放屏幕显示信息.但这部分地址空间实际上并没有全部使用.〔3〕扩展区ROM〔C0000H--DFFFFH〕该区128KB,由接口卡上的芯片提供支持,用于为系统不直接支持的外设安排设备驱动程序.用户固化的程序就可[安排在这一段,系统的会对它进行确认和连接.〔4〕系统区ROM〔E0000H--FFFFFH〕该区共128KB,由系统占用,它主要提供ROM--BIOS 程序,基本输入输出程序BIOS,是操作系统的重要组成部分,主要用来驱动输入输出设备,也负责系统的上电检测,磁盘引导等初始化操作,在ROM--BIOS中还有CMOS微机设置程序以与使用的字符图符信息等内容.〔习题1.15〕罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.〔解答〕〔1〕数据寄存器:AX称为累加器,使用频度最高,用于算术、逻辑运算以与与外设传送信息等;BX称为基址寄存器,常用做存放存储器地址;CX称为计数器,作为循环和串操作等指令中的隐含计数器;DX称为数据寄存器,常用来存放双字长数据的高16位,或存放外设端口地址.〔2〕指针与变址寄存器包括SI,DI,BP,S P,四个寄存器,常用于存储器寻址时提供地址.SI是源变址寄存器,DI是目的变址寄存器,一般与DS联用确定数据段和附加段中某一存储单元地址,在串指令中,SI与DS联用、DI和ES联用,分别寻址数据段和附加段;同时,在串指令中,SI和DI还都具有自动增量或减量的功能.S P,为堆栈指针寄存器,指示栈顶的偏移地址;BP为基地址指针寄存器,表示堆栈段中的基地址.S P与BP寄存器均可与SS段寄存器联合使用以确定堆栈段中的存储单元地址.〔习题1.16〕什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.〔解答〕标志用于反映指令执行结果或控制指令执行形式.它是汇编语言程序设计中必须特别注意的一个方面,状态用来记录运行的结果的状态信息,许多指令的执行都将相应地设置它,控制标志位可由程序根据需要用指令设置,用来控制处理器执行指令的方式.CF是进位标志;ZF 是零标志;SF是符号标志;PF奇偶标志;OF溢出标志;AF辅助进位标志;DF方向标志;IF中断允许标志;TF陷阱标志.〔习题1.17〕举例说明CF和OF标志的差异.〔解答〕溢出标志OF和进位标志CF是两个意义不同的标志.进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确.例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算:58+124=182 ,X围外,有溢出例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出〔习题1.18〕字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?〔解答〕字或双字在存储器中占相邻的2个或4个存储单元;存放时,低字节存入低地址,高字节存入高地址;字或双字单元的地址用它的低地址来表示.80x86处理器采用的这种"低对低,高对高〞的存储形式,被称为"小端方式〞;将字单元安排在偶地址,双字节单元安排在模4地址,被称为"地址对齐方式〞因为对于不对齐地址的数据,处理器访问时,需要额外的访问时间,所以通常应该将数据的地址对齐,以取得较高的存取速度.〔习题1.19〕什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h〔解答〕在8086处理器中,对应每个物理存储单元都有一个唯一的20位编号,就是物理地址,从00000H~FFFFFH.在8086内部和用户编程时,采用的段基地址: 段内偏移地址形式称为逻辑地址.将逻辑地址中的段地址左移二进制4位〔对应16进制是一位,即乘以16〕,加上偏移地址就得到20位物理地址如下逻辑地址用物理地址表达:〔1〕FFFFh:0=FFFF0H〔2〕40h:17h=00417H〔3〕2000h:4500h=24500H〔4〕B821h:4567h=BC777H 〔不要算错〕〔习题1.20〕8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令.堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据.数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据.附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据〔习题1.21〕数据的默认段是哪个,是否允许其他段存放数据?如果允许,如何实现,有什么要求?〔解答〕数据的默认段是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段,允许其它段存放数据,数据的存放比较灵活的,实际上可以存放在任何一种逻辑段中,这时,只要明确指明是哪个逻辑段就可以了.〔习题1.22〕什么是操作码、操作数和寻址方式?有哪三种给出操作数的方法?〔解答〕操作码说明计算机要执行哪种操作,它是指令中不可缺少的组成部分,操作数是指令执行的参与者,也是各种操作的对象,我们把寻找数的方式叫做操作数的寻址方式.给出操作数的三种方法是直接给出,间接给出,隐藏操作数方式给出.〔习题1.23〕什么是有效地址EA?8086的操作数如果在主存中,有哪些寻址方式可以存取它?〔解答〕。
钱晓捷新版汇编语言程序设计习题答案(修改)
![钱晓捷新版汇编语言程序设计习题答案(修改)](https://img.taocdn.com/s3/m/34772cd677eeaeaad1f34693daef5ef7ba0d12c1.png)
钱晓捷新版汇编语言程序设计习题答案第一章汇编语言基础知识1.1、简述计算机系统的硬件组成与各部分作用1.2、明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB1.3、什么是汇编语言源程序、汇编程序、目标程序?1.4、汇编语言与高级语言相比有什么优缺点?1.5、将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH1.6、将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕24581.7、将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕000000101.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕681.9、完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001〔5〕1011 ∧~1011 〔8〕1011 ⊕1001 1001〔6〕1011 ∨1001〔7〕1.10数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展.1.13、什么是DOS和ROM-BIOS?1.14、简述PC机最低1MB主存空间的使用情况.1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.1.16、什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.1.17、举例说明CF和OF标志的差异.溢出标志OF和进位标志CF是两个意义不同的标志进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确•例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算: 58+124=182 ,X围外,有溢出•例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出1.18、字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?1.19、什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h1.20、8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令•堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据•数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据•附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据第二章8086指令系统2.1已知DS = 2000H、BX = 0100H、SI = 0002H,存储单元[20100H] ~ [20103H]依次存放12 34 56 78H,[21200H] ~ [21203H]依次存放2A 4C B7 65H,说明下列每条指令执行完后AX寄存器的内容.〔1〕 mov ax,1200h ;AX=1200h〔2〕 mov ax,bx ; AX=0100h〔3〕 mov ax,[1200h] ; AX=4C2Ah〔4〕 mov ax,[bx] ; AX=3412h〔5〕 mov ax,[bx+1100h] ;AX=4C2Ah〔6〕 mov ax,[bx+si] ; AX=7856h〔7〕 mov ax,[bx][si+1100h] ; AX=65B7h2.2指出下列指令的错误<1> mov cx,dl 两操作数类型不匹配<2> mov ip,ax IP指令指针禁止用户访问<3> mov es,1234h 立即数不允许传给段寄存器<4> mov es,ds段寄存器之间不允许传送<5> mov al,300 两操作数类型不匹配<6> mov [sp],ax目的操作数应为[ BP ]<7> mov ax,bx+di源操作数应为[BX+DI]<8> mov 20h,ah立即数不能作目的操作数2.3已知数字0 ~ 9对应的格雷码依次为:18H、34H、05H、06H、09H、0AH、0CH、11H、12H、14H,它存在于以table为首地址〔设为200H〕的连续区域中.请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果.lea bx,table ;获取table的首地址,BX=200Hmov al,8 ;传送欲转换的数字,AL=8xlat ;转换为格雷码,AL=12H2.4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?堆栈是一种按"先进后出〞原则存取数据的存储区域.堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP.2.5已知SS = FFA0H、SP = 00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化?mov ax,8057hpush axmov ax,0f79hpush axpop bx ;bx=0f79hpop [bx] ;DS:[0f79h]=8057h2.6给出下列各条指令执行后AL值,以与CF、ZF、SF、OF和PF的状态:mov al,89h AL=89h CF ZF SF OF PFadd al,al AL=12h 1 0 0 1 1add al,9dh AL=0afh 0 0 1 0 1cmp al,0bch AL=0afh 1 0 1 0 1sub al,al AL=00h 0 1 0 0 1dec al AL=0ffh 0 0 1 0 1inc al AL=00h 0 1 0 0 12.7 设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;Z、Z+2的存储单元中,它们的运算结果存入W单元.阅读如下程序段,给出运算公式.mov ax,Xmov dx,X+2add ax,Yadc dx,Y+2add ax,24adc dx,0sub ax,Zsbb dx,Z+2mov W,axmov W+2,dxW=X+Y+24-Z2.8请分别用一条汇编语言指令完成如下功能:〔1〕把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器. ADD DX,BX〔2〕用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中.ADD AL,[BX+SI]〔3〕用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字和CX寄存器的内容相加,并把结果送回存储器中.ADD [BX+0B2H],CX〔4〕用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中. ADD WORD PTR [0520H],3412H〔5〕把数0A0H与AL寄存器的内容相加,并把结果送回AL中.ADD AL,0A0H2.9;设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处.为了避免与操作数地址混淆,将题中X,Y,Z,V 字操作数改为A,B,C,Dmov ax,X ;ax=Aimul Y ;dx,ax = A*B <将操作数看作符号数,以下同〕mov cx,axmov bx,dx ;bx,ax <-- dx,ax =A*Bmov ax,Z ;ax = Ccwd ;dx,ax =C 〔扩展符号后为双字〕add cx,axadc bx,dx ;bx,cx <-- bx,cx+dx,ax=A*B+Csub cx,540sbb bx,0 ;bx,cx<-- A*B+C-540mov ax, V ;ax= Dcwd ;dx,ax= D 〔扩展符号后为双字〕sub ax, cxsbb dx, bx ;dx,ax = dx,ax - bx,cx = D-<A*B+C-540>idiv X ;运算结果:[D-<A*B+C-540h>]/A ;ax存商,dx存余数2.10;〔1〕xchg [si],30h xchg的操作数不能是立即数〔2〕pop cs不能对CS直接赋值〔3〕 sub [si],[di] 两个操作数不能都是存储单元〔4〕push ah堆栈的操作数不能是字节量〔5〕 adc ax,ds adc的操作数不能是段寄存器〔6〕 add [si],80h没有确定是字节还是字操作〔7〕 in al,3fch in不支持超过FFH的直接寻址〔8〕 out dx,ah out只能以AL/AX为源操作数2.11; 给出下列各条指令执行后的结果,以与状态标志CF、OF、SF、ZF、PF的状态. 指令 AX的值CF OF SF ZF PFMov ax,1470h 1470h - - - - -And ax,ax 1470h0 0 0 00Or ax,ax 1470h 0 0 0 0 0Xor ax,ax 0 0 0 0 1 1Not ax 0ffffh - - - - -Test ax,0f0f0h 0ffffh 0 0 1 0 1注意: 1. mov, not指令不影响标志位2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位.2.12; 假设例题2.32的程序段中,AX = 08H,BX = 10H,请说明每条指令执行后的结果和注意:1. 左移N次相当于乘于2的N次方,右左移N次相当于除乘于2的N次方.2. 移位指令根据是否移入"1〞到CF,设置CF,根据移位后的结果影响SF,ZF,PF.根据最高符号位是否改变设置OF,如改变OF=1.3. ‘u ’表示无定义,‘- ’表示无影响.2.13编写程序段完成如下要求:<1> 用位操作指令实现AL〔无符号数〕乘以10;不考虑进位mov bl,almov cl,3shl al,cladd al,bl ;shl bl,1add al,bl;考虑进位xor ah,ahmov bx,axmov cl,3shl ax,cladd ax,bx ;shl bx,1add ax,bx<2> 用逻辑运算指令实现数字0 ~ 9的ASCII码与非压缩BCD码的互相转换数字0~9的ASCII码是:30h~39h非压缩BCD码的0~9是:00h~09h方法一:and al,0fh ;实现ASCII到非压缩BCD码的转换or al,30h ;实现非压缩BCD码到ASCII的转换方法二:xor al,30h ;求反D5D4位,其他不变;即高4位为3,则变为0;高4位为0,则变为3mov cl,4again: shr dx,1 ;实现逻辑右移;采用"sar dx,1〞,则实现算术右移rcr ax,1dec cljnz again<3> 把DX:.AX中的双字右移4位MOV CL, 4SHR AX, CLMOV BL, DLSHR DX, CLSHL BL, CLOR AH, BL2.14; 已知AL = F7H〔表示有符号数-9〕,分别编写用SAR和IDIV指令实现的除以2的程序段,并说明各自执行后,所得的商是什么?〔1〕用sar编写mov al,0f7h ;-9送alsar al,1 ;结果:al=0fbh 即-5〔2〕用idiv编写mov al,0f7h ;-9送alcbw ;字节符号扩展位字mov bl,2 ;注意除数不可为立即数idiv bl ;结果:商为al=fch <-4>;余数为ah=ffh <-1>结论:符号数的除法用idiv 准确2.15、已知数据段500h ~600h处存放了一个字符串,说明下列程序段执行后的结果:mov si,600hmov di,601hmov ax,dsmov es,axmov cx,256stdrep movsb2.16、说明下列程序段的功能cldmov ax,0fefhmov cx,5mov bx,3000hmov es,bxmov di,2000hrep stosw2.17、指令指针IP是通用寄存器还是专用寄存器?有指令能够直接它赋值吗?哪类指令的执行会改变它的值?调试程序DEBUG环境下,如何改变IP数值?2.18、控制转移类指令中有哪三种寻址方式?2.19;什么是短转移short jump、近转移near jump和远转移far jump?什么是段内转移和段间转移?8086有哪些指令可以实现段间转移?短转移:指段内-128~127之间的转移,位移量用一个字节表示近转移:指段内±32K之间的转移,位移量用一个字表示远转移:指段间1MB X围的转移段内转移:指在同一个代码段内的转移,可以是短转移或者近转移段间转移:指转移到另外一个代码段,就是远转移8086/8088CPU的JMP、CALL和INT n指令可以实现段间转移2.20; 8086的条件转移指令的转移X围有多大?实际编程时,你如何处理超出X围的条件转移?8086的条件转移的转移X围:在当前指令地址的+127---- -128之内.如条件转移的转移X围超出此X围,可在此X围内安排一条无条件转移,再转移到X围外的目标地址.2.21; 假设DS=2000H,BX=1256H,SI=528FH,位移量TABLE=20A1H,[232F7H]=3280H,[264E5H]=2450H,试问执行下列段内间接寻址的转移指令后,转移的有效地址是什么?<1>JMP Bx ;转移的有效地址EA=BX=1256h<2>JMP tABLE[Bx] ;转移的有效地址EA=[ds:20a1h+1256h]=[232f7]=3280h<3>JMP [Bx][si] ;转移的有效地址EA=[ds:1256h+528fh]=264e5h=2450h2.22、判断下列程序段跳转的条件〔1〕 xor ax,1e1ehje equal;AX=1e1eh〔异或后为0〕〔2〕test al,10000001bjnz there;AL的D0或D7至少有一位为1〔3〕 cmp cx,64hthere;CX〔无符号数〕< 64h2.23; 设置CX = 0,则LOOP指令将循环多少次?例如mov cx,0 ;不循环,因为一进入循环就判cx=0? 如cx=0 就退出循环delay:loop delay循环次数是2的16次方,即2^16=65536.2.24 假设AX和SI存放的是有符号数,DX和DI存放的是无符号数,请用比较指令和条件转移指令实现以下判断:〔1〕若DX > DI,转到above执行cmp dx,dija above ;=jnbe above〔2〕若AX > SI,转到greater执行cmp ax,sijg greater ;=jnle greater〔3〕若CX = 0,转到zero执行cmp cx,0 jcxz zerojz zero〔4〕若AX-SI产生溢出,转到overflow执行;cmp ax,dijo overflow〔5〕若SI≤AX,转到less_eq执行;cmp si,axcmp ax,sijle less_eqjge less_eq〔6〕若DI≤DX,转到below_eq执行.cmp di,dxcmp dx,die below_eqjae below_eq2.25有一个首地址为array的20个字的数组,说明下列程序段的功能.mov cx,20mov ax,0mov si,axsum_loop:add ax,array[si]add si,2loop sum_loopmov total,ax; 答:将首地址为array得20个字的数组求和,并将结果存入total 单元中.2.26 按照下列要求,编写相应的程序段:<1> 起始地址为string的主存单元中存放有一个字符串〔长度大于6〕,把该字符串中的第1个和第6个字符〔字节量〕传送给DX寄存器.mov si,0mov dl,string[si] ;第1个字符送dl寄存器mov si,5mov dh,string[si] ;第6个字符送dh寄存器<2> 从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低〔高〕地址对低〔高〕位的原则,将它们合并到DX中.xor si,si ;si清零mov al,buffer[si] ;第一字节inc simov ah,buffer[si] ;第二字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dl,al ;存入dl寄..inc simov al,buffer[si] ;第三字节inc simov ah,buffer[si] ;第四字节mov cl,4shl ah,cl ;BCD码移到高半字节or al,ah ;组合成压缩BCD码mov dh,al ;存入dh寄..<3> 编写一个程序段,在DX高4位全为0时,使AX = 0;否则使AX = -1.test dx,0f000hjz zeromov ax,-1jmp donezero: mov ax,0done: ret<4> 有两个64位数值,按"小端方式〞存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1-buffer2功能.lea bx,buffer1lea dx,buffer2mov cx,8 ;8个字节xor si,si ;si=0clc ;CF=0<5> 假设从B800h : 0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中.mov ax,0b800hmov ds,ax ;段地址xor si,si ;地址偏移量si=0xor dx,dx ;和的高字dx=0mov cx,99 ;加的次数mov ax,[si] ;第一个数again: inc si ;指向下一个字单元inc siadd ax,[si] ;加下一个数jnc noc ;无进位转inc dx ;有进位dx=dx+1noc: dec cx ;次数-1jnz cx,again ;非0继续加ret<6> 已知字符串string包含有32KB内容,将其中的’$’符号替换成空格.mov si,offset stringmov cx,8000h ;32k=2^15=8000hagain: cmp [si],’$’jnz nextmov [si],20h ;if [si]=’$’[si]<-- ’’next: inc siloop again<7> 有一个100个字节元素的数组,其首地址为array,将每个元素减1〔不考虑溢出〕存于原处.xor si,si ;si<--0mov cx,100 ;循环次数again: dec array[si]dec cxjnz again<8> 统计以’$’结尾的字符串srting的字符个数.xor si,si ;si<--0coun: cmp string[si],’$’je doneinc sijmp coundone: ret2.27; 对下面要求,分别给出3种方法,每种方法只用一条指令.<1>使CF=0 :clc ;and ax,ax ;or ax,ax<2>使AX=0 :xor ax,ax ;and ax,0 ;mov ax,0<3>同时使AX=0和CF=0:and ax,0 ;xor ax,ax ;sub ax,ax2.28、参照本习题的示意图,分析调用序列,画出每次调用与返回时的堆栈状态.其中CALL前是该指令所在的逻辑地址;另外,段内直接调用指令的机器代码的字节数为3,段间直接调用指令则为5个字节.2.29已知AX 、BX存放的是4位压缩BCD表示的十进制数,请说明如下子程序的功能和出口参数.add al,bldaaxchg al,ahadc al,bhdaaxchg al,ahret压缩BCD码加法:AX←AX+BX出口参数:AX=BCD码和2.30、AAD指令是用于除法指令之前,进行非压缩BCD码调整的.实际上,处理器的调整过程是:AL←AH×10+AL,AH←0.如果指令系统没有AAD指令,请用一个子程序完成这个调整工作.2.31、解释如下有关中断的概念:〔1〕内部中断和外部中断〔2〕单步中断和断点中断〔3〕除法错中断和溢出中断〔4〕中断向量号和中断向量表2.32、试比较INT n和段间CALL指令、IRET和段间RET指令的功能.2.33、什么是系统功能调用?汇编语言中,它的一般格式是怎样的?2.34; 补充例2.38,当有溢出时显示"Error! Overflow!〞,无溢出时显示"OK〞.okmsg db ‘OK’,‘$’errmsg db ‘Error! Overflow !’,‘$’…mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgjmp nextoverflow: mov dx,errmsgnext: mov ah,9int 21h错误:mov ax,Xsub ax,Yjo overflowmov dx,offset okmsgokmsg db ‘OK’,‘$’mov dx,errmsg ;错误1:数据定义在代码中mov ah,9int 21hoverflow: errmsg db ‘Error! Overflow !’,‘$’mov dx,errmsg ; 错误2:缺少JMP指令mov ah,9int 21h2.35、补充例2.39,显示"1〞的个数;注意首先将个数转换为ASCII码.2.36、先提示输入数字"Input Number:0 ~ 9〞,然后在下一行显示输入的数字,结束;如果不是键入了0 ~ 9数字,就提示错误"Error!〞,继续等待输入数字.2.37 从键盘输入一个字符串〔不超过255个〕,将其中的小写字母转换成大写字母,然后按原来的顺序在屏幕上显示.;xt237.asm.model small.stack.dataarray db 255db 0array1 db 255 dup<'$'>array2 db 0dh,0ah,'$'.code.startupmov ah,0ah ; 键盘输入字符串mov dx,offset arrayint 21hmov dx,offset array2 ; 回车换行mov ah,09hint 21hmov bx,offset array1again: mov al,[bx]cmp al,'$'jz donecmp al,'a' ; 小于a和大于z的字符不是小写字母nextcmp al,'z'ja nextsub al,20h ; 在a和z之间的字符才是小写字母,转换为大写mov [bx],al ; 保存到原位置next: inc bxjmp againdone: mov dx,offset array1mov ah,09hint 21h.exit 0end2.38、指令对状态标志的作用可以分成多种情况,例如无影响、无定义、按结果影响、特别说明的影响等,你能区别这些情况吗?分别用具体的指令来说明.2.39、8086指令系统分成哪6个功能组?各组主要包含什么指令,举例说明.2.40、总结8086指令系统所采用的各种寻址方式,包括一般的数据寻址、外设数据寻址、堆栈数据寻址、串操作数据寻址、转移指令目的地址的寻址等,并举例说明.另外找的!第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成与各部分作用.〔解答〕CPU:包括运算器、控制器和寄存器组.运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据.存储器:是计算机的记忆部件,它用来存放程序以与程序中所涉与的数据.外部设备:实现人机交换和机间的通信.〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快.辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢.RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息.存储器由大量存储单元组成.为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口.KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位.〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序.〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在"时间〞和"空间〞两方面最有效的程序.汇编语言与高级语言相比的缺点:由于与处理器密切相关导致通用性差、可移植性差,汇编语言功能有限,又涉与寄存器、主存单元等硬件细节,编写汇编语言比较繁琐,调试起来也比较困难,编译程序产生的目标程序往往比较庞大、程序难以优化,运行速度慢.〔习题1.5〕将下列十六进制数转换为二进制和十进制表示〔1〕FFH 〔2〕0H 〔3〕5EH 〔4〕EFH〔5〕2EH 〔6〕10H 〔7〕1FH 〔8〕ABH〔解答〕〔1〕FFH 11111111B 255D〔2〕0H 0B 0D〔3〕5EH 1011110B 94D〔4〕EFH 11101111B 239D〔5〕2EH 101110B 46D〔6〕10H 10000B 16D〔7〕1FH 11111B 31D〔8〕ABH 10101011B 171D〔习题1.6〕将下列十进制数转换为BCD码表示〔1〕12 〔2〕24 〔3〕68 〔4〕127〔5〕128 〔6〕255 〔7〕1234 〔8〕2458〔解答〕〔1〕12 00010010〔2〕24 00100100〔3〕68 01101000〔4〕127 000100100111〔5〕128 000100101000〔6〕255 001001010101〔习题1.7〕将下列BCD码转换为十进制数〔1〕10010001 〔2〕10001001 〔3〕00110110 〔4〕10010000〔5〕00001000 〔6〕10010111 〔7〕10000001 〔8〕00000010〔解答〕〔1〕91〔2〕89〔3〕36〔4〕90〔5〕08〔6〕97〔7〕81〔8〕02〔习题1.8〕将下列十进制数分别用8位二进制数的原码、反码和补码表示〔1〕0 〔2〕-127 〔3〕127 〔4〕-57〔5〕126 〔6〕-126 〔7〕-128 〔8〕68〔解答〕〔1〕0 +0 00000000 00000000 00000000-0 10000000 11111111 00000000〔2〕-127 11111111 10000000 10000001〔3〕127 01111111 01111111 01111111〔4〕-57 10101111 11010000 11010001〔5〕126 01111110 01111110 01111110〔6〕-126 11111110 10000001 10000010〔7〕-128 10000000〔8〕68 01000100 01000100 01000100〔习题1.9〕完成下列二进制数的运算〔1〕1011+1001 〔2〕1011-1001 〔3〕1011×1001 〔4〕10111000÷1001 〔5〕1011 ∧1001 〔6〕1011 ∨1001 〔7〕~1011 〔8〕1011 ? 1001 〔解答〕〔1〕1011+1001=10100〔2〕1011-1001=0010〔3〕1011×1001=1100011〔4〕10111000÷1001=10100,余数1000〔5〕1011 ∧1001=1001〔6〕1011 ∨1001=1011〔7〕~1011=0100<8> 1011?1001=0010<?代表异或>〔习题1.10〕数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?〔解答〕数码0~9:30H~39H大写字母A~Z:41H~5AH小写字母a~z:61H~7AHASCII码为0dh、0ah分别对应回车和换行控制字符.〔习题1.11〕计算机中有一个"01100001〞编码,如果把它认为是无符号数,它是十进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?〔解答〕十进制无符号数:01100001B=61H=97BCD码:61ASCII码:a〔习题1.12〕简述Intel 80x86系列微处理器在指令集方面的发展.〔解答〕1978年Intel,正式推出了16位8086CPU,1979年Intel推出了准16位微处理器8088,随后,Intel 推出了80186/80188,80186/80188指令系统比8086指令系统新增了若干条实用的指令,涉与堆栈操作、移位指令、过程指令和边界检测与乘法指令,1982年Intel推出80286 CPU, 80286指令系统包括全部80186指令与新增的保护指令15条,其中有些保护方式在实方式下也可以使用,1985年,Intel80x86推出微处理器地进入第三代80386 CPU, 80386指令系统在兼容原来16位指令系统的基础上,全面升级为32位,还新增了有关位操作、条件设置指令以与控制、调试和测试寄存器的传送指令等,1989年,Intel推出了80486CPU,80486将浮点处理单元FPU集成进来,还采用了精简指令集计算机技术RISC和指令流水线方式,还新增了用于多处理器和内部Cache操作的6条指令,1993年Intel制成了俗称586的微处理器,取名Pentium.Pentium仍为32位结构,地址总线为32位,对常用的简单指令用硬件实现,重新设计指令的微代码等,Pentium新增了一条8字节比较交换指令和一条处理器识别指令,以与4条系统专用指令,1996年推出了MMX Pentium,新增了57条多媒休指令,1995年Intel推出Pentium Pro新增了3条指令,1999年推出了PentiumⅢ新增了70条SSE指令,20##推出的Pentium4新增了76条SSE2指令〔习题1.13〕什么是DOS和ROM-BIOS?〔解答〕DOS是Diskette Operating system的缩写,意思是磁盘操作系统,DOS主要是面向磁盘的系统软件,说得简单些,就是人与机器的一座桥梁,是罩在机器硬件外面的一层"外壳〞,是1981~1995年的个人电脑上使用的一种主要的操作系统.BIOS〔Basic Input/Output System〕即基本输入输出系统,通常是固化在只读存储器〔ROM〕中,所以又称为ROM-BIOS.它直接对计算机系统中的输入、输出设备进行设备级、硬件级的控制,是连接软件程序和硬件设备之间的枢纽.ROM-BIOS是计算机系统中用来提供最低级、最直接的硬件控制的程序.〔习题1.14〕简述PC机最低1MB主存空间的使用情况.〔解答〕〔1〕基本RAM区<00000H—9FFFFH>该区共640KB,由DOS进行管理.在这个区域中操作系统要占用掉一部分低地址空间,其它则向用户程序开放.〔2〕保留区RAM〔A0000H--BFFFFFH〕该区为系统安排的"显示缓冲存储区〞,共126KB,是显卡上的芯片提供支持,用于存放屏幕显示信息.但这部分地址空间实际上并没有全部使用.〔3〕扩展区ROM〔C0000H--DFFFFH〕该区128KB,由接口卡上的芯片提供支持,用于为系统不直接支持的外设安排设备驱动程序.用户固化的程序就可[安排在这一段,系统的会对它进行确认和连接.〔4〕系统区ROM〔E0000H--FFFFFH〕该区共128KB,由系统占用,它主要提供ROM--BIOS 程序,基本输入输出程序BIOS,是操作系统的重要组成部分,主要用来驱动输入输出设备,也负责系统的上电检测,磁盘引导等初始化操作,在ROM--BIOS中还有CMOS微机设置程序以与使用的字符图符信息等内容.〔习题1.15〕罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用.〔解答〕〔1〕数据寄存器:AX称为累加器,使用频度最高,用于算术、逻辑运算以与与外设传送信息等;BX称为基址寄存器,常用做存放存储器地址;CX称为计数器,作为循环和串操作等指令中的隐含计数器;DX称为数据寄存器,常用来存放双字长数据的高16位,或存放外设端口地址.〔2〕指针与变址寄存器包括SI,DI,BP,S P,四个寄存器,常用于存储器寻址时提供地址.SI是源变址寄存器,DI是目的变址寄存器,一般与DS联用确定数据段和附加段中某一存储单元地址,在串指令中,SI与DS联用、DI和ES联用,分别寻址数据段和附加段;同时,在串指令中,SI和DI还都具有自动增量或减量的功能.S P,为堆栈指针寄存器,指示栈顶的偏移地址;BP为基地址指针寄存器,表示堆栈段中的基地址.S P与BP寄存器均可与SS段寄存器联合使用以确定堆栈段中的存储单元地址.〔习题1.16〕什么是标志,它有什么用途?状态标志和控制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义.〔解答〕标志用于反映指令执行结果或控制指令执行形式.它是汇编语言程序设计中必须特别注意的一个方面,状态用来记录运行的结果的状态信息,许多指令的执行都将相应地设置它,控制标志位可由程序根据需要用指令设置,用来控制处理器执行指令的方式.CF是进位标志;ZF 是零标志;SF是符号标志;PF奇偶标志;OF溢出标志;AF辅助进位标志;DF方向标志;IF中断允许标志;TF陷阱标志.〔习题1.17〕举例说明CF和OF标志的差异.〔解答〕溢出标志OF和进位标志CF是两个意义不同的标志.进位标志表示无符号数运算结果是否超出X围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出X围,运算结果已经不正确.例1:3AH + 7CH=B6H无符号数运算:58+124=182,X围内,无进位有符号数运算:58+124=182 ,X围外,有溢出例2:AAH + 7CH=〔1〕26H无符号数运算:170+124=294,X围外,有进位有符号数运算:-86+124=28 ,X围内,无溢出〔习题1.18〕字和双字在存储器中如何存放,什么是"小端方式〞?对字和双字存储单元,什么是它们的对齐地址?为什么要对齐地址?〔解答〕字或双字在存储器中占相邻的2个或4个存储单元;存放时,低字节存入低地址,高字节存入高地址;字或双字单元的地址用它的低地址来表示.80x86处理器采用的这种"低对低,高对高〞的存储形式,被称为"小端方式〞;将字单元安排在偶地址,双字节单元安排在模4地址,被称为"地址对齐方式〞因为对于不对齐地址的数据,处理器访问时,需要额外的访问时间,所以通常应该将数据的地址对齐,以取得较高的存取速度.〔习题1.19〕什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达:〔1〕FFFFh:0 〔2〕40h:17h 〔3〕2000h:4500h 〔4〕B821h:4567h〔解答〕在8086处理器中,对应每个物理存储单元都有一个唯一的20位编号,就是物理地址,从00000H~FFFFFH.在8086内部和用户编程时,采用的段基地址: 段内偏移地址形式称为逻辑地址.将逻辑地址中的段地址左移二进制4位〔对应16进制是一位,即乘以16〕,加上偏移地址就得到20位物理地址如下逻辑地址用物理地址表达:〔1〕FFFFh:0=FFFF0H〔2〕40h:17h=00417H〔3〕2000h:4500h=24500H〔4〕B821h:4567h=BC777H 〔不要算错〕〔习题1.20〕8086有哪4种逻辑段,各种逻辑段分别是什么用途?〔解答〕代码段〔Code Segment〕用来存放程序的指令序列.处理器利用CS : IP取得下一条要执行的指令.堆栈段〔Stack Segment〕确定堆栈所在的主存区域.处理器利用SS : SP操作堆栈中的数据.数据段〔Data Segment〕存放当前运行程序所用的数据.处理器利用DS : EA存取数据段中的数据.附加段〔Extra Segment〕是附加的数据段,也用于数据的保存.处理器利用ES : EA存取数据段中的数据〔习题1.21〕数据的默认段是哪个,是否允许其他段存放数据?如果允许,如何实现,有什么要求?〔解答〕数据的默认段是安排在数据段,也经常安排在附加段,尤其是串操作的目的区必须是附加段,允许其它段存放数据,数据的存放比较灵活的,实际上可以存放在任何一种逻辑段中,这时,只要明确指明是哪个逻辑段就可以了.〔习题1.22〕什么是操作码、操作数和寻址方式?有哪三种给出操作数的方法?〔解答〕操作码说明计算机要执行哪种操作,它是指令中不可缺少的组成部分,操作数是指令执行的参与者,也是各种操作的对象,我们把寻找数的方式叫做操作数的寻址方式.给出操作数的三种方法是直接给出,间接给出,隐藏操作数方式给出.〔习题1.23〕什么是有效地址EA?8086的操作数如果在主存中,有哪些寻址方式可以存取它?〔解答〕。
汇编语言程序设计(第四版)【课后答案】
![汇编语言程序设计(第四版)【课后答案】](https://img.taocdn.com/s3/m/0927ec72b0717fd5370cdca8.png)
汇编语言程序设计第四版【课后习题答案】第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成及各部分作用。
〔解答〕CPU:包括运算器、控制器和寄存器组。
运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。
存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。
外部设备:实现人机交换和机间的通信。
〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB。
〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。
辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。
RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息。
存储器由大量存储单元组成。
为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口。
KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位。
〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。
〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第4章基本汇编语言程序设计〔习题4.1〕例题4.2如果要求算术右移8位,如何修改程序。
〔解答〕思路:首先由最高位字节向次低位字节传送……次低位字节向最低位字节传送(共7次);再判最高位字节符号位,如为0,送00h到最高位字节;如为1,送ffh到最高位字节。
传送可参考例题4.2,不过应从第一号字节送第零号字节,……最高位字节向次低位字节传送;也可以用循环来完成:.model small.stack 256.dataqvar dq 1234567887654321h.code.startupmov cx,7mov si,1again: mov al, byte ptr qvar[si]mov byte ptr qvar[si-1],alinc siloop againtest al,80hjz ezzmov bl,0ffhjmp doneezz: mov bl,0done: mov byte ptr qvar[7],bl.exit 0end〔习题4.2〕例题4.2如果要求算术左移7位,如何用移位指令实现。
〔解答〕思路:可设计外循环体为8个字节左移一次,方法是:最低位字节算术左移一次,次低位字节至最高位字节依次带 CF 位循环左移一次(循环共8次),外循环体控制执行7次即可。
.model small.stack 256.dataqvar dq 1234567887654321h.code.startupmov dx, 7 ;外循环次数mov ax, byte ptr qvar[0] ;最低位字节送axlpp: shl ax,1 ;最低位字节左移一次,其d7移入CF位mov si, 1mov cx, 7 ;循环次数again: rcl byte ptr qvar[si], 1 ;高位字节依次左移 P50 inc siloop againdec dxjnz lpp.exit 0.end〔习题4.3〕将AX寄存器中的16位数连续4位分成一组,共4组,然后把这4组数分别放在AL、BL、CL和DL寄存器中。
〔解答〕思路:设这四组从低位到高位分别放在AL、BL、CL和DL寄存器中。
仅列出代码段:mov bl, al ;将al中的两组分开and al, 0fh ;屏蔽高四位后送almov cl, 4 ;原al中的数据逻辑右移4次送blshr bl, clmov dl, ah ;将ah中的两组分开and dl, 0f0h ;屏蔽低高四位后送dlmov cl, 4 ;原ah中的数据逻辑右移4次送dlshr dl, clmov cl, ah ;屏蔽高四位后送cland cl, 0fh〔习题4.4〕编写一个程序,把从键盘输入的一个小写字母用大写字母显示出来。
〔解答〕getkey: mov ah, 1 ;从键盘输入,出口:al存键值int 21hcmp al, 'a' ;判键值是小写字母?jb getkaycmp al, 'z'ja getkaysub al,20h ;是小写字母转换为大写字母mov dl,almov ah, 02h ;显示int 21h〔习题4.5〕已知用于LED数码管显示的代码表为:LEDtable DB 0c0h,0f9h,0a4h,0b0h,99h,92h,82h,0f8hDB 80h,90h,88h,83h,0c6h,0c1h,86h,8eh它依次表示0 ~ 9、A ~ F这16个数码的显示代码。
现编写一个程序实现将lednum中的一个数字(0 ~ 9、A ~ F)转换成对应的LED显示代码。
〔解答〕.model small.stack 256.dataLEDtable DB 0c0h,0f9h,0a4h,0b0h,99h,92h,82h,0f8hDB 80h,90h,88h,83h,0c6h,0clh、86h,8ehlednum DB ?.code.startupmov bx, offset LEDtablemov al, lednumxlat ;al中存有对应的LED显示代码.exit 0end〔习题4.6〕请问第2章例题2.39 / 2.41 / 2.43 / 2.46的分支是单分支、双分支或多分支结构?〔解答〕例题2.43/2.45/2.47 为单分支结构;2.50为多分支结构。
〔习题4.7〕分析第2章例题2.40的分支结构,画出流程图。
〔解答〕〔习题4.8〕如果在例题4.4的table中依次填入msg1 ~ msg8,程序应该怎样修改?〔解答〕(1)将jmp table[bx]指令改为:mov dx, table[bx](2)去掉源程序中:.exit 0---end之间的语句〔习题4.9〕编制一个程序,把变量bufX和bufY中较大者存入bufZ;若两者相等,则把其中之一存入bufZ中。
假设变量存放的是8位无符号数。
〔解答〕.model small.stack 256.databufx db ?bufY db ?bufz db ?.code.startupmov al, bufXmov bl, bufYcmp al,blja nextmov bufZ, bljmp donenext: mov bufZ, aldone: .exit 0end〔习题4.10〕设变量bufX为有符号16位数,请将它的符号状态保存在signX,即:如果X 大于等于0,保存0;如果X小于0,保存-1(ffh)。
编写该程序。
〔解答〕.model small.stack.databufX dw -7signX db ?.code.startupcmp bufX,0 ;test bufX,80hjl next ;jnz nextmov signX,0jmp donenext: mov signX,-1done: .exit 0end〔习题4.11〕bufX、bufY和bufZ是3个有符号16进制数,编写一个比较相等关系的程序:(1)如果这3个数都不相等,则显示0;(2)如果这3个数中有两个数相等,则显示1;(3)如果这3个数都相等,则显示2。
〔解答〕.model small.stack 256.databufx dw ?bufY dw ?bufz dw ?.code.startupmov ax, bufXmov bx, bufYmov cx, bufZmov dl, '0'cmp ax,bxjnz next1inc dlnext1: cmp ax,cxjnz next2inc dlnext2: cmp bx,cxjnz next3inc dlnext3: cmp dl,’3’jb next4mov dl,’2’next4: mov ah,02h ;显示int 21h.exit 0end〔习题4.12〕分析第2章例题2.42、2.52、2.53的结构,分别画出它们的流程图。
〔解答〕2.422.522.53〔习题4.13〕例题4.8外循环次数共是多少?如果要求按从大到小排序,程序如何修改?〔解答〕外循环次数是: count-1次(19次)循环次数是:(count-1)!次 ( 19! 次)外循环次数共是 count-1 + (count-1)!次,即 19+19!次〔习题4.14〕串操作指令常要利用循环结构,现在不用串操作指令实现字符串string1容传送到字符串string2,字符长度为count。
〔解答〕.model small.stack 256.datastring1 db 'good morning!'len = $-string1string2 db len dup(?).code.startupmov cx, len ;字符数mov si, offset string1 ;源指针mov di, offset string2 ;目标指针again: mov al, [si] ;送一个字符mov [di], alinc si ;修改指针inc di ;修改指针loop again ;cx=cx-1,cx=0时退出循环.exit 0end〔习题4.15〕不用串操作指令求主存0040h : 0开始的一个64KB物理段中共有多少个空格?〔解答〕这里仅列出主程序段:mov ax,0040h ;送段地址mov ds, axxor si, si ;偏移量地址xor cx, cx ;计数(循环次数)xor dx, dx ;空格计数器清零again: cmp [si], 20h ;与空格的ASCII码比较jne next ;不是空格,转inc dx ;是空格,空格数加1 next: inc si ;修改地址指针loop again ;cx=cx-1,如cx=0 退出循环.exit 0end〔习题4.16〕编程实现把键入的一个字符,用二进制形式(0 / 1)显示出它的ASCII代码值。
〔解答〕.model small.stack 256.datastri1 db 'please input',0dh,0ah,'$'.code.startupmov dx,offset stri1mov ah,09hint 21hmov ah, 01hint 21hmov cx, 8again: xor dl,dlshl al, 1adc dl, '0'mov ah,02hint 21hloop again.exit 0end〔习题4.17〕编写程序,要求从键盘接收一个数bellN(0 ~ 9),然后响铃bellN次。
〔解答〕.model small.stack.datastri1 db 'please input number:1--9',0dh,0ah,'$'.code.startupagain: mov dx,offset stri1 ;显示stri1,提示输入mov ah,09hint 21hmov ah,01h ;调用输入一个字符int 21h ;输入一个字符存在al中cmp al, '1' ;判该字符,如不在‘1’--‘9’jb again ;重新输入cmp al, '9'ja againand al,0fh ;在‘1’--‘9’,屏蔽高4位mov cl, al ;振铃次数送cxxor ch,chabc: mov dl, 07h ;调用一次振铃mov ah, 02hint 21hloop abc.exit 0end〔习题4.18〕编写程序,将一个包含有20个有符号数据的数组arrayM分成两个数组:正数数组arrayP和负数数组arrayN,并分别把这两个数组中的数据个数显示出来。