单片机原理及应用思考题_第1页
单片机原理及应用思考题_第2页
单片机原理及应用思考题_第3页
单片机原理及应用思考题_第4页
单片机原理及应用思考题_第5页
已阅读5页,还剩30页未读 继续免费阅读

下载本文档

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

文档简介

单片机原理及应用思考题第1页,共35页,2023年,2月20日,星期三1.顺序程序设计例4.1请用MCS-51汇编指令编写程序,将片内RAM104、105单元中的内容分别传送到片外RAM104H、105H单元中。分析:应注意片内和片外的寻址指令不同第2页,共35页,2023年,2月20日,星期三ORG1000HMOVR0,#68HMOVA,@R0 ;片内RAM104单元内容送累加器MOVDPTR,#0104HMOVX@DPTR,A ;完成片内RAM104单元内容送片

;外104H单元中INCR0MOVA,@R0 ;片内RAM105单元内容送累加器INCDPTRMOVX@DPTR,A ;完成片内RAM105单元内容送片

;外105H单元中SJMP$ ;等待END ;结束第3页,共35页,2023年,2月20日,星期三1.简单分支程序YN

顺序执行条件满足?转向目标程序2.分支程序设计图4.1简单分支程序转移第4页,共35页,2023年,2月20日,星期三分析:只要将两数进行比较,用比较的结果作为分支转移的条件就很容易地找出其中的大数。

已知片内RAMFIRST开始的两个单元中各存放有一个8位无符号二进制数,要求找出其中的大数并存入片内RAM的SECOND单元中。例4.2第5页,共35页,2023年,2月20日,星期三 ORG1000H CLRC MOVR0,#FRIST ;第一个数地址送R0中

MOVA,@R0 ;取第一个数

INCR0 ;R0指向第二个数地址

SUBBA,@R0 ;两数比较

JCBIG ;第二个数大转BIG DECR0 ;R0指向第一个数地址BIG: MOVSECOND,@R0;存大数

SJMP$;等待

END;结束参考程序第6页,共35页,2023年,2月20日,星期三2)多路分支程序(散转程序)K=n

K=n-1

K=2

转向分支n-1

转向分支2

转向分支1

转向分支nK=?

K=1

…图4.2多路分支程序转移第7页,共35页,2023年,2月20日,星期三1)把AJMP或LJMP指令组成一个分支程序的

转移表,表的首地址放入DPTR中;2)调整后的出口信息放入累加器A中;3)执行JMP@A+DPTR转向对应的分支程序。

可通过间接转移指令JMP@A+DPTR和无条件转移指令中的AJMP或LJMP指令来实现多路分支转移:第8页,共35页,2023年,2月20日,星期三例4.3

已知R0中存放有一数字关键码,要求根据码值的不同,分别转向对应的码值程序段去执行。即当(R0)=K时,便执行CODEK程序。第9页,共35页,2023年,2月20日,星期三

ORG1000HMOVDPTR,#TAB ;表首址送DPTRMOVA,R0 ;取数字关键码

ADDA,R0 ;每条AJMP指令占用两个字

;节,将出口信息乘2JNCLESS ;关键码小于128转LESSINCDPHLESS:JMP@A+DPTR

TAB:AJMPCODE0 ;关键码为0,转CODE0执行

AJMPCODE1 ;关键码为1,转CODE1执行

……AJMPCODE255 ;关键码为255,转CODE255

;执行

SJMP$ ;等待

END ;结束参考程序第10页,共35页,2023年,2月20日,星期三

AJMP指令的转移范围不超出所在的2KB字节区间,如各小段程序较长,在2KB字节内无法全部容纳,上面的程序应该怎样修改?思考第11页,共35页,2023年,2月20日,星期三1)循环初始化

设置循环的初始状态,位于循环程序的开头位置2)循环处理

循环程序的主体部分,是通过反复执行来完成数据的具体处理,它位于循环体内。3.循环程序设计循环程序由4部分组成:第12页,共35页,2023年,2月20日,星期三3)循环控制

也在循环体内,是用于控制循环的继续与否。4)循环结束

通常位于循环体后,是用来存放循环处理的最终结果及恢复各寄存器与工作单元的原始值。第13页,共35页,2023年,2月20日,星期三

设MCS-51单片机内部RAM从40H开始的连续16个单元中,每个单元中分别存放有单字节的带符号数。要求将其中的正数存入50H开始的连续单元中,负数存入60H开始的连续单元中,并将正数、负数和零的个数分别存入70H、71H、72H单元中。例4.4第14页,共35页,2023年,2月20日,星期三1) 带符号数的最高位为符号位,可通过 最高位判断正负:“0”表示正数,“1” 表示负数。2) 程序中需要从40H单元开始取源数, 存正数和负数,故需要三个地址指针 来指向对应的内存单元;设对应的地 址指针分别为R0、R1和R2,由于R2 不能用间接寻址方式,故R2需要同R1 或R0进行交换后,才能进行负数的存 放。

分析第15页,共35页,2023年,2月20日,星期三图4.3程序流程图第16页,共35页,2023年,2月20日,星期三参考程序:

ORG1000HCLRAMOV70H,A ;存放正数的个数单元清0MOV71H,A ;存放负数的个数单元清0MOV72H,A ;存放零的个数单元清0MOVR3,#10H ;设循环计数器初值

MOVR0,#40H ;设源数地址指针

MOVR1,#50H ;设正数地址指针

MOVR2,#60H ;设负数地址指针第17页,共35页,2023年,2月20日,星期三LOOP:MOVA,@R0 ;取源数

JZ

ZERO

;源数为0,转ZER0JNBACC.7,POSI

;源数为正,转POSI

INC71H ;负数个数加1MOVR4,A ;暂存原数

MOVA,R2XCHA,R1 ;R1与R2中的内容交换

XCHA,R4MOV@R1,A ;存负数

XCHA,R4XCHA,R1 ;R1与R2中的内容交换

INCR2 ;调整负数地址指针

SJMP

LOOP1

;转循坏控制第18页,共35页,2023年,2月20日,星期三POSI:INC70H ;正数个数加1MOV@R1,A ;存正数

INCR1 ;调整正数地址指针

SJMPLOOP1ZERO:INC72H ;零的个数加1LOOP1:INCR0 ;调整源数地址指针

DJNZR3,LOOP ;未送完,继续

SJMP$ ;等待

END ;结束第19页,共35页,2023年,2月20日,星期三查表指令有:

MOVCA,@A+DPTRMOVCA,@A+PC

查表就是把事先计算或测得的数据按照一定的顺序编制成表格存放在存储器中,然后根据输入的数据,从表格中查出所需的结果。4.查表程序设计第20页,共35页,2023年,2月20日,星期三

片内RAM的EGA单元中有一个大写的英文字母,要求将此字母在英文字母表中的位置送入片内的COUNT单元中,如EGA单元中字母为I时,则COUNT单元中需送入数字9。例4.6第21页,共35页,2023年,2月20日,星期三如果将26个英文字母按照顺序编成一个表,通过查表法得到一个字母与EGA单元中的字母比较,若不相等再查,同时记录查表的次数。查完后,将记录次数送COUNT单元。分析第22页,共35页,2023年,2月20日,星期三参考程序

ORG1000HEGAEQU50HCOUNTEQU60HMOVCOUNT,#00HMOVA,#16 ;调整地址LOOP:PUSHAMOVCA,@A+PC;查表

CJNZA,EGA,NF ;所查字母与EGA中字母比较

SJMPLAST ;相等转LASTNF:POPAINCA ;调整地址

INCCOUNT ;记数值加1SJMPLOOP ;继续查LAST:INCCOUNT ;记数值加1SJMP$ ;等待ALPT:DB‘A’,‘B’,…,‘Y’,‘Z’END ;结束第23页,共35页,2023年,2月20日,星期三编写子程序时应注意:a.子程序的第一条指令之前必须有标号;b.子程序中需要保护现场;c.主程序和子程序之间的参数传递。5.子程序设计第24页,共35页,2023年,2月20日,星期三

已知片内BLOCKB单元开始处有一数据块,块长在R2中,在此数据块的每个单元中存放有一个未组合的BCD码,要求将每个BCD码转换为ASCAII码,并存放在片内BLOCKA开始的连续单元中。例4.8BCD码转换为ASCAII码第25页,共35页,2023年,2月20日,星期三将一位BCD码转换为ASCAII码的子程序:TRANS: MOVA,@R0 ;取BCD码

ADDA,#30H MOV@R1,A ;送ASCAII码

INCR0 INCR1 RET ;返回分析:将一位BCD码转换为相应的ASCAII码只需加上30H即可。第26页,共35页,2023年,2月20日,星期三

主程序:

ORG1000HMOVR2,#LMOVR0,#BLOCKB ;设BCD码的地址指针

MOVR1,#BLOCKA ;设ASCAII的地址指针LOOP:ACALLTRANS ;调用TRANS子程序

DJNZR2,LOOP ;未转换完,继续

SJMP$ ;等待

END ;结束第27页,共35页,2023年,2月20日,星期三

设片内40H单元中有一组合的BCD码,要求将其转换为二进制数存回原处。分析:

1)组合的BCD码为两位十进制数,需将十位 数和个位数分开处理。

2)十位数转换时只要累加0AH就能将其转换 为相应的二进制数,然后再将个位数直接 加到转换后的十位数上就可完成整个数的 转换。例4.9BCD码转换为二进制数第28页,共35页,2023年,2月20日,星期三参考程序

ORG1000BCDTOB: MOVA,40H ANLA,#F0H ;取十位数

SWAPA ;将十位数换到低4位

JZDONE ;十位数为0,返回

MOVR3,#00H ;累加和寄存器清0LOOP: DECA

ACALLADD0AH ;调用加10子程序

JNZLOOP ;未加完继续

MOVA,40H ANLA,#0FH ;取个位数

ADDA,R3 ;与十位相加

MOV40H,A ;转换完,存结果DONE: RET

;(书上此处有错)第29页,共35页,2023年,2月20日,星期三ADD0AH:PUSHA;保护现场

MOVA,R3;累加的和送A中

ADDA,#0AHMOVR3,A;加10后送回原处

POPA;恢复现场

RET;返回

加10子程序:第30页,共35页,2023年,2月20日,星期三

已知片内RAMADR1开始的单元依次从低位到高位存放有L个字节的无符号数,片外RAMADR2开始的单元也依次从低位到高位存放有L个字节的无符号数。请编一个加法程序,将他们的和存放在ADR1开始的连续单元中。2)算术运算子程序例4.11多字节无符号数相加第31页,共35页,2023年,2月20日,星期三R0:片内RAM地址指针,初值为ADR1DPTR:片外RAM地址指针,初值为ADR2每完成一个字节的加法后,R0、DPTR各自加1,调整为加数、被加数下一待加字节的地址。R2:计数器。存放待加的字节数,每完成一个字节的加法后,内容减1,当R2=0时,程序结束。第32页,共35页,2023年,2月20日,星期三开始#ADR1→(R0)

温馨提示

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

评论

0/150

提交评论