当前位置:首页 > 第3章 单片机的汇编语言与程序设计题解
第3章 单片机的汇编语言与程序设计 习题
1.MCS-51单片机有哪几种寻址方式?适用于什么地址空间?
答:MCS-51单片机有7种寻址方式:直接寻址、寄存器寻址、寄存器间接寻址、立即寻址、变址寻址、位寻址、相对寻址。
直接寻址方式:操作数的地址由指令直接给出,适用于片内RAM的所有地址空间;如 MOV A,68H
MOV A,PSW 寄存器寻址方式:指令给出的是寄存器的编码,操作数在编码指定的寄存器中,适用于片内00H至1FH的32个字节,用R0,…,R7表示,通过PSW的RS1和RS0选择组号确定对应32个字节中的其中8个,还有累加器A,以及乘除法指令中的A和B寄存器,位寻址方式中的布尔累加器C;
MOV A,R1 MUL AB INC DPTR 寄存器间接寻址方式:指令给出的是寄存器的编码,操作数地址在编码指定的寄存器中,适用于片内RAM的全部空间,其中52系列中的80H至FFH只能用寄存器间接寻址;如 MOV A,@R0
MOV A,@R1 MOVX A,@DPTR 立即寻址方式:操作数本身在指令中直接,给出适用于用8位立即数对片内RAM所有地址单元赋值,也可用16位立即数对DPTR赋值; 如
MOV A,#0E2H MOV DPTR,#2000H 变址寻址方式:以DPTR或PC作为基地址寄存器,以累加器A作为变址寄存器,将基址寄存器与变址寄存器的内容相加形成操作数的实际地址的一种寻址方式,变址寻址方式适用于程序存储器ROM,仅有三条指令如下:
MOVC A,@A+DPTR
MOVC A,@A+PC JMP @A+DPTR
位寻址方式:指令中直接给出操作数所在单元的位地址,适用于片内RAM中地址20H至2FH中的16个字节中的128个位地址空间和80H至FFH中地址中可以被8整除的所有SFR中的每个位地址空间;如
MOV C,7FH MOV F0,C MOV C,ACC.7
相对寻址方式:为相对转移指令而设,指令中直接给出转移的相对偏移量,其转移目标在当前指令-128至+127字节范围内的地址空间。如 SJMP START
HERE: SJMP HERE ;等效于: SJMP $ 2.MCS-51单片机的PSW程序状态字中无ZERO(零)标志位,怎样判断某内部数据单元的内容是否为零?
答:MCS-51单片机的PSW程序状态字中无ZERO(零)标志位,判断某内部数据单
元的内容是否为零是能通过取数到A累加器,再判断A中的每一位是否为零来确定其值是否为零。
3.编程将内部RAM的20H--30H单元内容清零。
解:设一个片内RAM指针R0,先指向首地址20H,通过累加器A清零,然后采用间接寻址方式依次将A中的零值传送到指针所指的片内RAM单元,每传送一个字节,地址指针加1,直到达到地址为30H或达到计数器规定的17个字节为止。 程序1: MOV R0,#20H ;设地址指针初值 CLR A ;累加器清0 CONT: MOV @R0,A ;置0指针所指单元 INC R0 ;地址指针加1
CJNE R0,#31H,CONT ;指针未超过终点则继续 SJMP $ ;暂停 程序2: MOV R0,#20H ;设地址指针初值 CLR A ;累加器清0 MOV R7,#17 ;计数器赋初值,从20H到30H共17个字节 CONT: MOV @R0,A ;置0指针所指单元 INC R0 ;地址指针加1
DJNZ R7, CONT ;计数器减1,非0,则继续 SJMP $ ;暂停 4.编程查找内部RAM的32H~41H单元中是否有0AAH这个数据,若有这一数据,则将50H单元置为0FFH,否则将50H单元清零。
解:设一个片内RAM指针R0,先指向首地址32H,比较@R0与#0AAH,若相等,则退出循环,给50H单元赋0FFH,若不相等,则R0加1为继续比较下一个字节做准备,直到达到地址为41H或达到计数器规定的16个字节为止还没找到,则给50H单元赋00H 程序1: MOV R0,#32H ;设地址指针初值
CONT: CJNE @R0,#0AAH,NEXT;比较查找值与指针所指单元的值,不相等转移 MOV A,#0FFH ;相等,则准备好要赋的标志值0FFH SJMP DOWN ;转存到保存结果处 NEXT: INC R0 ;修改地址指针
CJNE R0,#42H,CONT ;若指针未越过终点,则继续 MOV A,#00H ;查找失败,则将00H存入结果标志单元 DOWN: MOV 50H,A ;将比较结果标志存入50H单元 SJMP $ ;暂停 END 程序2: MOV R7,#16 ;计数器赋初值,从20H到30H共16个字节 MOV R0,#32H ;设地址指针初值
CONT: CJNE @R0,#0AAH,NEXT ;比较查找值与指针所指单元的值,不相
等转移
MOV A,#0FFH ;相等,则准备好要赋的标志值0FFH SJMP DOWN ;转存到保存结果处 NEXT: INC R0 ;修改地址指针
DJNZ R7,CONT ;计数器减1,非0,则继续 MOV A,#00H ;查找失败,则将00H存入结果标志单元 DOWN: MOV 50H,A ;将比较结果标志存入50H单元 SJMP $ ;暂停 END
5.查找20H~4FH单元中出现00H的次数,并将查找结果存入50H单元。 解:从20H到4FH共48个字节 MOV R7,#48 ;字节计数器赋初值
MOV R0,#20H ;设地址指针初值
CONT: CJNE @R0,#00H,NEXT ;比较查找值与指针所指单元的值,不相等转移 INC R6 ;相等,0的个数计数器加1 NEXT: INC R0 ;修改地址指针
DJNZ R7,CONT ;计数器减1,非0,则继续 MOV 50H,R6 ;保存O的个数计数值到50H单元 SJMP $ ;暂停 END END
6.已知A=83H,R0=17H,(17H)=34H,写出下列程序段执行之后的A中的内容。 ANL A,#17H ORL 17H,A XRL A,@R0 CPL A END 答:
ANL A,#17H ;A=03H ORL 17H,A ;(17H)=0011 0100 ∨ 0000 0011=0011 0111 XRL A,@R0 ;A= 0000 0011 ∨ 0011 0111 =0011 0100 CPL A ;A=1100 1011
7.已知单片机的晶振频率为12MHz,分别设计延时为0.1s、1s的子程序。 答:已知单片机的晶振频率为12MHz,则机器周期为1us,延时子程序是通过执行指令序列中机器周期数来达到,如果要0.1s,即100ms,也就是100000us,所以需要机器周期数达到100000。要延时达到1S,可通过对延时为0.1秒的子程序调用10次来实现。 DELAY100MS: MOV R6,#200 ;1个机器周期 D1: MOV R7,#250 ;1个机器周期 D2: NOP ;1个机器周期 DJNZ R7,D2 ;2个机器周期,3*251=753 DJNZ R6,D1 ;2个机器周期,(1+753+2)*132=99792 RET ;2个机器周期,1+99792+2=99795,约100ms
DELAY1S: MOV R7,#10 ;计数10次 1 LOOP: ACALL DELAY100MS ;延时100ms子程序 99795+2
DJNZ R7,LOOP ;未达到10次则继续 10*(2+99795+2) RET ;返回2+10*(2+99795+2)=997992
8.内部RAM从20H单元开始处有一数据块,以ODH为结束标志,试统计该数据块的长度,将该数据块送到外部数据存储器7E01H开始的单元,并将长度存入7E00H单元。
解:从20H的指针用R0,从外部RAM7E01开始的指针用DPTR,计数器用R7 MOV R7,#0 ;字节计数器赋初值 MOV R0,#20H ;设片内RAM地址指针初值 MOV DPTR,#7E01H ;设片外RAM地址指针初值 CONT: MOV A,@R0 ;取片内RAM中的一个字节 MOVX @DPTR,A ;存入片外RAM指针所指单元 INC R7 ;长度计数器加1 INC R0 ;片内RAM地址指针加1 INC DPTR ;片外RAM地址指针加1 CJNE A,#0DH,CONT ;未达到结束标志 MOV A,R7 ;取块计数长度值 MOVX @DPTR,A ;保存 SJMP $ ;暂停 END
9.内部RAM从DATA开始的区域中存放着10个单字节十进制数,求其累加和,并将结果存入SUM和SUM+1单元。
解:R7计数,R6保存累加和高8位,R0用作地址指针 ORG 0000H LJMP MAIN ORG 100H SUM EQU 30H DATAA EQU 40H MAIN: MOV R7,#10 ;字节计数器赋初值 MOV R0,#DATAA ;设片内RAM地址指针初值 CLR A ;累加器清0 MOV R6,A ;累加结果的高8位 CONT: ADD A,@R0 ;加RAM中的一个字节到ACC DA A JNC NEXT ;若无进位则不用管高8位 INC R6 ;有进位,高8位加1 NEXT: INC R0 ;片内RAM地址指针加1 DJNZ R7,CONT ;未完继续 MOV SUM,A ;保存低8位 MOV SUM+1,R6 ;保存高8位 SJMP $ ;暂停 END 10.内部RAM从DATA1和DATA2单元开始处存放着两个等长的数据块,数据块的
长度在LEN单元中。请编程检查这两个数据块是否相等,若相等,将0FFH写入RESULT单元,否则将0写入RESULT单元。
解:从DATA1开始的指针用R0,从DATA2开始的指针用R1,计数器用R7 LEN EQU 10 DATA1 EQU 30H DATA2 EQU 40H RESULT EQU 50H MOV R7,#LEN ;字节计数器赋初值 MOV R0,#DATA1 ;设片内RAM地址指针初值 MOV R1,#DATA2 ;设片外RAM地址指针初值 CONT: MOV A,@R0 ;取片内RAM R0所指的的一个字节 MOV 7FH,@R1 ;将R1所指单元内容取到片内RAM地址7FH中 CJNE A,7FH,NOEQ ;比较,不相等则结束 INC R0 ;DATA1 RAM地址指针加1 INC R1 ;DATA2 RAM地址指针加1 DJNZ R7,CONT ;未完,继续 MOV A,#0FFH ;相等,准备写入FFH SJMP DOWN ;转写入结果处 NOEQ: MOV A,#0 ;不相等,准备写入00H DOWN: MOV RESULT,A ;保存比较结果标志 SJMP $ ;暂停 END
11.编制程序,将内部RAM中M1、M2、M3和M4单元中的无符号数xl、x2、x3和x4相加,并把和存入RO和R1(R0中为高8位)中。 解:
M1 EQU 30H M2 EQU 40H M3 EQU 45H M4 EQU 4FH MOV A,M1 ;取第一个数 ADD A,M2 ;与第二个数相加 JNC NEXT1 ;如果无进位,则转移至第三个相加 MOV R0,#1 ;有进位,高8位置1 NEXT1: ADD A,M3 ;与第三个数相加 JNC NEXT2 ;没有进位,则转至第四个数相加 INC R0 ;有进位,高8位加1 NEXT2: ADD A,M4 ;与第四个数相加 JNC NEXT3 ;没有进位,则转至结束 INC R0 ;有进位,高8位再加1 NEXT3: MOV R1,A ;低8位保存到R1 SJMP $ ;暂停 END
共分享92篇相关文档