第四章汇编语言程序设计
- 格式:docx
- 大小:34.76 KB
- 文档页数:17
新版汇编语言程序设计习题答案(钱晓捷主编)第一章汇编语言基础知识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系列微处理器在指令集方面的发展。
《汇编语言程序设计》教案附:习题参考答案《汇编语言程序设计》(第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 章 基础知识【教学目的】本章内容是本课程的基础,通过本章学习,使学生明确汇编语言程序设计的学科性质、基本内容和学习意义,掌握数制的转换、数据的编码,了解本门课程的教学要求和学习方法。
汇编语言及编程实例(电子教案)汇编语言程序设计2005第四章汇编语言程序设计回顾:8086的内部结构、寄存器功能和工作过程,指令格式、寻址方式和功能。
本讲重点:了解汇编的概念及其方法,掌握汇编程序的基本格式,常用运算符的使用方法,汇编的步骤。
4.1汇编语言的基本元素一、汇编语言的语句格式由汇编语言编写的源程序是由许多语句(也可称为汇编指令)组成的。
每个语句由1~4个部分组成,其格式是:[标号]指令助记符[操作数][;注解]其中用方括号括起来的部分,可以有也可以没有。
每部分之间用空格(至少一个)分开,一行最多可有132个字符。
1.标识符给指令或某一存储单元地址所起的名字。
可由下列字符组成:字母:A~z;数字:0~9;特殊字符:、·、@、一、$数字不能作标识符的第一个字符,而圆点仅能用作第一个字符。
标识符最长为31个字符。
当标识符后跟冒号时,表示是标号。
它代表该行指令的起始地址;当标识符后不带冒号时,表示变量;伪指令前的标识符不加冒号。
2.指令助记符表示不同操作的指令,可以是8086的指令助记符,也可以是伪指令。
3.操作数指令执行的对象。
依指令的要求,可能有一个、两个或者没有,例如:RET;无操作数COUNT:INCC某;一个操作数如果是伪指令,则可能有多个操作数,例如:COSTDB3,4,5,6,7;5个操作数MOVA某,[BP+4];第二个操作数为表达式4.注解该项可有可无,是为源程序所加的注解,用于提高程序的可读性。
二、汇编语言的运算符1.算术运算符、逻辑运算符和关系运算符-1-汇编语言程序设计2005算术运算符可以应用于数字操作数,结果也是数字。
而应用于存储器操作数时,只有+、-运算符有意义。
2.取值运算符SEG、OFFSET、TYPE、SIZE和LENGTH·SEG和OFFSET分别给出一个变量或标号的段地址和偏移量。
例如,定义:SLOTDW25则:MOVA某,SLOT;从SLOT地址中取一个字送入A某MOVA某,SEGSLOT;将SLOT所在段的段地址送入A某MOVA某,OFFSETSLOT;将SLOT所在段的段内偏移地址送A某·TYPE操作符返回一个表示存储器操作数类型的数值。
汇编语言程序设计第二版汇编语言是一种低级编程语言,它使用助记符来表示机器指令,允许程序员直接控制硬件。
汇编语言程序设计第二版是针对那些希望深入理解计算机系统底层工作机制的程序员和计算机科学学生编写的教材。
本书在第一版的基础上进行了更新和扩充,以适应现代计算机体系结构和编程实践的发展。
第一章:汇编语言基础本章介绍了汇编语言的基本概念,包括指令集、寄存器、内存寻址方式以及指令的格式和操作。
通过实例代码,读者可以初步了解如何使用汇编语言编写简单的程序。
第二章:数据表示和运算数据在计算机中的表示是程序设计的基础。
本章详细讨论了不同数据类型(如整数、浮点数和字符)在汇编语言中的表示方法,以及基本的算术和逻辑运算。
第三章:程序控制结构程序控制结构是程序设计中的重要组成部分。
本章讲解了条件语句、循环、跳转等控制结构在汇编语言中的实现方式,并通过实际例子展示了如何使用这些结构来编写更复杂的程序。
第四章:子程序和参数传递子程序是程序设计中常用的模块化技术。
本章介绍了如何在汇编语言中定义和调用子程序,以及参数传递的机制。
此外,还讨论了堆栈的使用和调用约定。
第五章:输入输出和中断处理现代计算机系统通常需要与外部设备交互。
本章讲解了汇编语言中实现输入输出的方法,包括直接内存访问(DMA)和中断驱动的I/O。
同时,介绍了中断服务程序的编写。
第六章:高级汇编技术随着计算机技术的发展,汇编语言也引入了一些高级技术,如宏定义、条件汇编和模块化编程。
本章对这些高级技术进行了深入的探讨,并提供了相应的编程实例。
第七章:系统级编程系统级编程涉及到操作系统的底层接口。
本章介绍了如何在汇编语言中实现系统调用,以及如何处理进程和线程的创建和管理。
第八章:性能优化性能是程序设计中的一个重要考虑因素。
本章讨论了汇编语言程序的性能优化技巧,包括指令选择、循环展开和流水线优化等。
第九章:安全性和可维护性随着软件安全和可维护性的重要性日益增加,本章讨论了在汇编语言编程中如何实现代码的安全性和可维护性,包括错误处理、异常处理和代码审查。
知识点第一章基础知识(1)正负数的补码表示, 掌握计算机中数和字符的表示;eg.假设机器字长为8位,[+3]补=00000011B,[-3]补= 11111101 H 。
十六进制数0FFF8H表示的十进制正数为65528D,表示的十进制负数为-8D。
8位二进制数被看成是带符号补码整数时,其最小值是-128,最大值是 127 。
第二章80x86计算机组织(1)中央处理机CPU的组成和80x86寄存器组,重点:专用寄存器,段寄存器eg: IP寄存器中保存的是?代码段中的偏移地址FLAGS标志寄存器中共有几位条件状态位6位,有几位控制状态位2位,标志寄存器分为哪2类?陷阱标志,中断标志。
(2)存储单元的地址和内容每一个字节单元给以一个唯一的存储器地址,称为物理地址;一个存储单元中存放的信息称为该存储单元的内容。
存储器地址的分段,(低位字节存放)低地址,(高位字节存放)高地址;实模式下逻辑地址、选择器和偏移地址;物理地址的表示段基地址加上偏移地址。
eg.如果SS=6000H,说明堆栈段起始物理地址是_____60000H___。
已知字节(00018H)=14H,字节(00017H)=20H,则字(00017H)为__1420H______。
如果(SI)=0088H,(DS)=5570H,对于物理地址为55788H的内存字单元,其内容为0235H,对于物理地址为5578AH的内存字单元,其内容为0E60H,那么执行指令LDS SI,[SI]以后,(SI)= 0235H ,(DS)= 0E60H .第三章80x86的指令系统和寻址方式与数据有关的寻址方式(立即寻址方式,寄存器寻址方式,直接寻址方式,寄存器间接寻址方式,寄存器相对寻址方式,基址变址寻址方式,相对基址变址寻址方式)和与转移地址有关的寻址方式(段内直接寻址,段内间接寻址,段间直接寻址,段间间接寻址)。
数据传送指令(通用数据传送指令、累加器专用传送指令、输入输出指令)、算术指令(加法指令、减法指令(*加减指令对4个标志位的影响[of,cf,sf,zf])、乘法指令(*乘法指令的要求:目的操作数必须是累加器)、除法指令(*被除数在累加器中,除法指令执行完以后,商和余数在?))、逻辑指令(逻辑运算指令(*XOR,AND,OR,TEST指令及指令执行后对标志位的影响)、移位指令)、串处理指令(与REP相配合工作的MOVS、STOS、LODS 指令,与REPE/REPZ和REPNE/REPNZ联合工作的CMPS、SCAS指令)、控制转移指令(无条件转移指令、条件转移指令、循环指令、子程序调用指令、中断)。
第四章汇编语言程序设计 1 / 17 第四章 汇编语言程序设计 1、编程将片内40H~60H单元中的内容送到以3000H为首的存储区内。
答:MOVR1,#40H MOVR2,#21H MOVDPTR,#3000H L1:MOVA,@R1 MOVX@DPTR,A INCR1 INCDPTR DJNZR2,L1 2、编程计算下列算式的程序 (1)23H+45H+ABH+03H= MOVA,#23H ADDA,#45H ADDA,#0ABH XCHA,B;溢出处理 ADDCA,#00H XCHA,B ADDA,#03H;A中为结果低位,B中为高位 (2)CDH+15H-38H-46H= MOVA,#0CDH ADDA,#15H SUBBA,#38H SUBBA,#46H (3)1234H+8347H= MOVA,#34H ADDA,#47H MOV30H,A MOVA,#12H ADDCA,#83H MOV31,A;30H存结果低位,31H存结果高位 (4)AB123H-43ADCH= CLRC MOVA,#23H SUBBA,DCH 第四章汇编语言程序设计 2 / 17 MOV30H,A MOVA,#0B1H SUBBA,#3AH MOV31H,A MOVA,#0AH SUBBA,,#04H MOV32H,A;30H为低位,32H为高位 3、设有两个4位BCD码,分别存放在23H、22H单元和33H、32H单元中,求他们的和,并送入43H、42H单元中(低位在低字节,高位在高字节)。 答:MOVA,22H ADDA,32H MOV42H,A MOVA,23H ADDCA,33H MOV43H,A 4、略 5、编程计算片内RAM区50H~59H单元中数的平均值,结果存放在5AH中。 答:MOVR0,#8 MOVR1,#50H MOVA,#00H L1:ADDA,@R1 INCR1 DJNZR0,L1 MOVB,#8 DIVAB MOV5AH,A 6、编写计算下式的程序。设乘积和平方结果均小于255。a 、b值分别存在片外3001H和3002H单元中,结果存于片外3000H单元中。 (1) MOVDPTR,#3001H MOVXA,@DPTR MOV30H,A;a暂存30H单元 INCDPL MOVXA,@DPTR CJNEA,30H,L1;是否a=b 第四章汇编语言程序设计 3 / 17 MOVA,#25 SJMPSAVE L1:JNCL2 MOVB,30H MULAB SJMPSAVE L2:MOVB,A MOVA,30H DIVAB SAVE:MOVDPTR,#3000H MOVX@DPRT,A (2) MOVDPTR,#3001H MOVXA,@DPTR MOV30H,A INCDPTR MOVXA,@DPTR ADDA,30H MOVB,A MULAB; (a+b)2 MOV31H,A CJNEA,#10,L1 SJMPSAVE L1:JCL2 CLRC SUBBA,#10 SJMPSAVE L2:ADDA,#10 SAVE:MOVDPTR,#3000H MOVC@DPTR,A 7、设有两个长度均为15的数组,分别存放在以200H和210H为首地址的存储区中,试编程求其对应项之和,结果存放到以220H为首地址的存储区中。 答:MOVDPH,#02H MOVR1,#15 MOVR2,#00H; 数组1首地址低位 第四章汇编语言程序设计 4 / 17 MOVR3,#10H; 数组2首地址低位 MOVR4,#20H; 和首地址低位 L1:MOVDPL,R2 MOVXA,@DPTR MOVR1,A MOVDPL,R3 MOVXA,@DPTR ADDA,R1 MOVDPL,R4 MOVX@DTPR,A INCR2 INCR3 INCR4 DJNZR1,L1 SJMP$ 8、设有100个无符号数,连续存放在以2000H为首地址的存储区中,试编程统计正数、负数和零的个数。 答:MOV30H,#00H;正数计数器 MOV31H,#00H;负数计数器 MOV32H,#00H;零计数器 MOVDPTR,#2000H MOVR1,#100 L4:MOVXA,@DPTR INCDPTR CJNEA,#0,L1 INC32H SJMPL2 L1:JCL3 INC30H SJMPL2 L3:INC31H L2:DJNZR1,L4 SJMP$ 9、将片外数据存储器地址为1000H~1030H的数据块,全部搬迁到片内RAM 30H~60H中,并将原数据块区域全部清零。 第四章汇编语言程序设计 5 / 17 答:MOV R0,#30H MOV R2,#31H MOV DPTR ,#1000H LP:MOVX A,@DPTR MOV @R0,A AND A,#00H MOVX @DPTR,A INC R0 INC DPTR DJNZ R2,LP SJMP$
10、试编写一子程序,是R1、R0指向的两个片外RAM连续单元中的高4位二进制数,合并成一个字节,装入累加器A中。已知R0指向低地址,并要求该单元高四位放在A中高四位。 答:MOVXA,@R1 ANLA,#0F0H SWAPA MOVR2,A MOVXA,@R0 ANLA,#0F0H ORLA,R2 11、试编程把以2040H为首地址的连续50个单元的无符号数按降序排列,存放到以3000H为首地址的存储区中。 答:MOVR2,#50 MOVR3,#20H MOVR4,#40H;源地址 MOVR5,#30H MOVR6,#00H;目的地址 SEND:MOVDPH,R3;SEND将2040H数据块移入3000H存储区 MOVDPL,R4 MOVXA,@DPTR INCDPTR MOVR3,DPH 第四章汇编语言程序设计 6 / 17 MOVR4,DPL MOVDPH,R5 MOVDPL,R6 MOVX@DPTR,A INCDPTR MOVR5,DPH MOVR6,DPL DJNZR2,SEND MOVR2,#49;重复次数 CMP1:MOVDPTR,#3000H MOVR3,#49;比较次数 CMP2:MOVXA,@DPTR MOVB,A INCDPTR MOVXA,@DPTR CJNEA,B,L1 L1:JCNOMOVE MOV30H,A CLRC MOVA,DPL SUBBA,#01H MOVDPL,A MOVA,30H MOVX@DPTR,A INCDPTR MOVA,B MOVX@DPTR,A NOMOVE:DJNZR3,CMP2;50个数重复一遍? DJNZR2,CMP1;排序结束? LJMP$ 12、试编一查表程序,从首地址为2000H,长度为100的数据块中找出ASCII码为A,将其地址送到20A0H和20A1H单元中。 答:MOVDPTR,#2000H MOVR2,#100 GO_ON:MOVXA,@DPTR 第四章汇编语言程序设计 7 / 17 CJNEA,#41H,IFEND MOVA,DPH MOVB,DPL MOVDPTR,#20A0H MOVX@DPTR,A INCDPTR XCHA,B MOVX@DPTR,A SJMPOVER IFEND:INCDPTR DJNZR2,GO_ON OVER:SJMPOVER 13、设在200H~204H单元中,存放5个压缩BCD码,编程将他们转换成ASCII码,存放到以205H单元为首地址的存储区。 答:MOVR2,#05H MOVR3,#02H MOVR4,#00H MOVR5,#02H MOVR6,#05H CHLP:MOVDPH,R3 MOVDPL,R4 MOVXA,@DPTR INCDPTR MOVR3,DPH MOVR4,DPL MOVB,A SWAPA ANLA,#0FH ORLA,#30H MOVDPH,R5 MOVDPL,R6 MOVX@DPTR,A INCDPTR MOVA,B ANLA,#0FH 第四章汇编语言程序设计 8 / 17 ORLA,#30H MOVX@DPTR,A MOVR5,DPH MOVR6,DPL DJNZR2,CHLP 14、有一无符号数据块长度在30H单元中,其首地址为31H单元,求出数据块中最大值,并存入40H中。 答:MOVR0,#31H MOVR1,30H MOV40H,#00H LOOP:MOVA,@R0 CJNEA,40H,L1 SJMPAGAIN L1:JNCL2 SJMPAGAIN L2:MOV40H,A AGAIN:INCR0 DJNZR1,LOOP SJMP$ 15、略 16、在以2000H为首地址的存储区内,存放20个用ASCII码表示的0~9之间的数,试编程,将它们转换成BCD码,并以压缩BCD码的形式存在3000H~3009H单元中。 答:MOVR2,#10 MOVR3,#20H MOVR4,#00H MOVR5,#30H MOVR6,#00H LP:MOVDPH,R3 MOVDPL,R4 MOVXA,@DPTR ANLA,#0FH SWAPA XCHA,B INCDPTR