分支与循环程序的设计.docx
《分支与循环程序的设计.docx》由会员分享,可在线阅读,更多相关《分支与循环程序的设计.docx(16页珍藏版)》请在冰豆网上搜索。
分支与循环程序的设计
实验名称分支与循环程序设计成绩
指导教师******
专业班级******姓名白***学号*******
联系********
一、任务要求
1.熟练掌握Keil环境下汇编语言程序的调试方法,加深对汇编语言指令、机器码、寻址方式等基本容的理解,掌握分支程序和简单程序的设计与调试方法,了解并行IO口的使用。
2.设有8bits符号数X存于外部RAM单元,按以下方式计算后的结果Y也存于外部RAM单元,请按要求编写完整程序。
3.利用51系列单片机设计一个24小时制电子时钟,电子时钟的时、分、秒数值分别通过P0、P1、P2端口输出(以压缩BCD码的形式)。
P3.0为低电平时开始计时,为高电平时停止计时。
设计1s延时子程序(延时误差小于10us,晶振频率12MHz)。
4.1)实现4位十进制加、减1计数,千位、百位由P1口输出;十位、个位由P2口输出。
利用P3.7状态选择加、减计数方式。
2)利用P3口低四位状态控制开始和停止计数,控制方式自定。
二、设计思路
1.先在外部RAM取数,然后判断该符号数是否为负数,若为负数,则取相反数并存数;若为正数,则接着判断该数是否大于等于64,若满足,则求平方并存数,先存低位,后存高位;若小于64,则接着判断该数是否大于10,若满足,则求该数的一半并存数;若小于等于10,则取相反数并存数。
2.第一步先编可以延时1S的子程序DELAY;接着判断P3.O是否满足开始计数条件,若不满足,则重复判断;若满足,则对时分秒分别赋值,调用延时子程序,判断是否满足计时条件,若不满足,则重复判断直至满足;若满足,则秒钟自加一,循环,判断秒钟循环满60次后出循环,对分钟自加一,然后继续循环,最后判断分钟循环满60次后出循环,对时钟自加一,然后判断时钟循环满24则回到初值,时分秒重新赋值并重新开始循环。
3.判断P3.7,若为1,则进行加一计数,若为0,则跳转至另一程序进行减一计数;加一计数中,先取低位P1送A,自加一,送P1,判断是否有溢出,若有,则取高位P2送A,自加一,送P2,然后回判断循环;减一计数同理,即先取低位P1送A,自减一,送P1,判断是否有进位,若有,则取高位P2送A,自减一,送P2,然后回判断继续循环。
三、资源分配
1.2000H片外RAM存数
2001H存结果低八位
2002H存结果高八位
B寄存器暂存结果高八位
2.P3.0存计时判断位
R0、R1、R2存延时子程序中各重循环的循环次数
R3、R4、R5存时分秒的循环次数
P0、P1、P2存时分秒的输出值
3.P1、P2分别存十进制计数的低两位、高两位
P3.7存计数方式的控制位
四、流程图
1、8bit符号数的判断与计算
2、时钟设计
3.十进制加减一计数器
五、源代码(含文件头说明、语句行注释)
1.8bit符号数的判断与计算
ORG0000H
LJMPSTART
ORG1000H
START:
MOVDPTR,#2000H;地址指针赋初值
MOVA,#22
MOVXDPTR,A
MOVXA,DPTR;取数
JBACC.7,DD
CJNEA,#64,AA;若A≠64,则转AA
AA:
JCBB;若A<64,则转BB
MOVB,A
MULAB;求A的平方
INCDPTR
MOVXDPTR,A;存结果低八位
INCDPTR
MOVA,B
MOVXDPTR,A;存结果高八位
SJMP$
BB:
CJNEA,#10,CC;若A≠10,则转CC
CPLA
EE:
INCDPTR
MOVXDPTR,A
SJMP$
CC:
JCDD;若A<10,则转DD
RRA;若A>10,则右移一位
SJMPEE
DD:
CPLA
INCA
SJMPEE
END
2.时钟设计
ORG0000H
LJMPSTART
ORG1000H
START:
JBP3.0,START;若为0,则开始计时
RESTA:
MOVR3,#24
MOVP0,#00H;时钟赋初值
LOOP3:
MOVR4,#60
MOVP1,#00H;分钟赋初值
LOOP2:
MOVR5,#60
MOVP2,#00H;秒钟赋初值
LOOP1:
ACALLDELAY;调用延时1S子程序
LOOP:
JBP3.0,LOOP;若为1,则停止计时
MOVA,P2
ADDA,#01H
DAA
MOVP2,A
DJNZR5,LOOP1;判断秒钟是否结束循环
MOVA,P1
ADDA,#01H
DAA
MOVP1,A
DJNZR4,LOOP2;判断分钟是否结束循环
MOVA,P0
ADDA,#01H
DAA
MOVP0,A
DJNZR3,LOOP3;判断时钟是否结束循环
LJMPRESTA
DELAY:
MOVR0,#12
NOP
DELAY3:
MOVR1,#130
DELAY2:
MOVR2,#212
NOP
NOP
DELAY1:
NOP
DJNZR2,DELAY1
DJNZR1,DELAY2
DJNZR0,DELAY3
RET
END
3.十进制加减计数器
ORG0000H
LJMPSTART
ORG1000H
START:
MOVP1,#12H
MOVP2,#92H
LOOP:
ACALLDELAY
MOVA,P2
JBP3.7,AA;若为1,则转AA实现记数加1
ADDA,#99H
DAA;实现十进制减1
MOVP2,A
JCBB;判断是否产生借位,若产生,则对高位减1
MOVA,P1
ADDA,#99H
DAA
MOVP1,A
AJMPLOOP
AA:
ADDA,#01H
DAA;实现十进制加1
MOVP2,A
JNCBB;判断是否产生进位,若产生,则对高位加1
MOVA,P1
ADDA,#01H
DAA
MOVP1,A
BB:
AJMPLOOP
DELAY:
MOVR0,#12
NOP
DELAY3:
MOVR1,#130
DELAY2:
MOVR2,#212
NOP
NOP
DELAY1:
NOP
DJNZR2,DELAY1
DJNZR1,DELAY2
DJNZR0,DELAY3
RET
END
六、程序测试方法与结果
1.8bit符号数的判断与计算
1)令片外RAM中数据为64
2)令片外RAM中数据为22
3)令片外RAM数据为1
4)令片外RAM数据为-2
2.时钟设计
1)令P3.0=0,程序按十进制正常运行
2)令P3.0=0,暂停计数
3)设置断点观察延时子程序的延时时间,刚好为1s
3.十进制加减1计数器
1)将P3.7置1,计数器实现加一计数
2)将P3.7置0,计数器实现减一计数
七、思考题
1.实现多分支结构程序的主要方法有哪些?
举例说明。
a)分支地址表法
b)转移指令表法
c)地址偏移量表法
2.在编程上,十进制加1计数器与十六进制加1计数器的区别是什么?
怎样用十进制加法指令实现减1计数?
a)十进制加1计数器满十进1,十六进制加1计数器满16进1,十进制加法需用DAA指令进行调整
b)用ADDA,#99H
DAA指令,即可实现减1计数
本人承诺:
本报告内容真实,无伪造数据,无抄袭他人成果。
本人完全了解学校相关规定,如若违反,愿意承担其后果。
签字:
白如海
2017年10月20日
其它说明:
1.标题:
黑体,小四号
2.正文:
宋体,五号,1.5倍行距
3.流程图使用SmartDraw7或Visio软件绘制
4.不要加封面