分支程序设计实验实验报告

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
四、流程图:
1.分支函数程序流程图
2.电子时钟程序流程图
3.四进制加、减1计数程序流程图
各图形如下:
大于或等于40
小于或等于20来自百度文库
大于20
电子时钟:
NO
YES
NO
YES
NO
YES
加减计数器流程图:
YES
NO NO
YES YES
YES YES
NO NO
五、源代码:
1)
ORG 0000H
MOV A,#50H
a.实现4位十进制加、减1计数,千位、百位由P1口输出;十位、个位由P2口输出。利用P3.7状态选择加、减计数方式。
b.利用P3口低四位状态控制开始和停止计数,控制方式自定。
二、设计思路:
1.分支函数程序设计:首先将X赋给累加器A,与40比较大小,将大于或等于40的执行乘方操作;小于40的再与20做比较,大于20的执行取除法操作,小于或等于20的执行取反操作。最后将计算结果Y存于片外的RAM上。
MOV B,A
MUL AB
MOV DPTR,#2001H ;低位存入片外RAM中2001H
MOVX @DPTR,A
INC DPTR
MOV A,B
MOVX @DPTR,A;高位存入片外RAM中2002H
STOP:SJMP $
END
2)
ORG 0000H
MOV R0,#0;R0,R1,R2置0
MOV R1,#0
MOV P2,#0H
JUDGE:CLR C
MOV C,P3.7
JNC ADDDONE
SUBDDONE:MOV P0,#99H
MOV P1,#99H
2.电子时钟程序:A:累加器C:位操作P0、P1、P2:分别电子时钟的时、分、秒输出R0、R1、R2:分别时分秒计数用存储器
R3、R4、R5:完成1s延时的相关数据存储
3.四位十进制加、减1计数程序:A:累加器C:位操作P0:低位输出口P1:高位输出口R0:高位寄存器R1:低位寄存器R7 R6:分别临时储存低位和高位的寄存器
MOV R2,#0
MOV P0,#0;P0,P1,P2置0
MOV P1,#0
MOV P2,#0
INPUT:JNB P3.0,STEP
START: ACALL DELAY
INC R0;秒钟计数
MOV A,R0
ACALL OUTPUT;转化为bcd码
MOV P2, A
CJNE R0,#60,START;60进制判断进1
实验二分支程序设计实验实验报告
实验名称:分支程序设计实验
指导教师罗志祥
专业班级光信1006姓名张博学号U201013339联系方式
一、任务要求:
熟练掌握KeilC环境下汇编语言程序的调试方法,加深对汇编语言指令、机器码、寻址方式等基本内容的理解,掌握分支程序和简单程序的设计与调试方法,了解并行IO口的使用。
MOV DPTR,#2000H
MOVX @DPTR,A ;将数存入片外RAM
MOV DPTR,#2000H
MOVX A,@DPTR;从片外RAM中取数X
MOV R7,A
CLR C
MOV R0,#40H;对X的值进行比较
SUBB A,R0
JNCMUTI
MOV R1,#20H
CLR C
MOV A,R1
SUBB A,R7
1.设有8bits符号数X存于外部RAM单元,按以下方式计算后的结果Y也存于外部RAM单元,请按要求编写程序。
2.利用51系列单片机设计一个24小时制电子时钟,电子时钟的时、分、秒数值分别通过P0、P1、P2端口输出(以压缩BCD码的形式)。P3.0为低电平时开始计时,为高电平时停止计时。
提高部分(选做):
MOV P0,A
CJNE R2,#24,START;判断是不是溢出了
MOV R2,#0;溢出清0
MOV P0,#0;输出清0
SJMP INPUT;跳出循环
DELAY:MOV R3,#19H;循环次数
LOOP:MOV R4,#28H
LOOP1:MOV R5,#0FAH;循环次数
LOOP2:NOP
NOP
2.电子时钟程序设计思路:首先用循环程序的嵌套实现一个1s的延时,同时让记秒的端口P2同步加一,到60后清零;再让此循环执行60次实现1min的延时,同时让P1同步加一,到60后清零;再让分钟的循环执行24次,实现1hour的延时,同时让P0同步加一。至此循环,即可实现24小时的时钟功能。(注:本计算机的晶振频率为12MHz)
MOV R0,#0;
MOV P2,#0;
INC R1;分钟计数
MOV A,R1
ACALL OUTPUT;转化为bcd码
MOV P1,A
CJNE R1,#60,START;60进制判断
MOV R1,#0;
MOV P1,#0;
INC R2;时钟计数
MOV A,R2;
ACALL OUTPUT;计算bcd码
DJNZ R5,LOOP2
DJNZ R4,LOOP1
DJNZ R3,LOOP
SJMP START
RET
OUTPUT:MOV B,#0AH;
DIV AB
SWAP A
ORL A,B
RET
DONE:SJMP $
STEP:SJMP STEP
END
3)
ORG 0000H
MOV P0,#0H
MOV P1,#0H
3.4位十进制加、减1计数程序思路:低位的个位和十位赋给一个寄存器,而将高位即百位千位赋给另外一个寄存器,通过循环程序使低位数循环100次即向高位进位或借位,高位循环100次后即回归初始状态,同时设计两个子函数分别执行加一、减一操作。其中,用P3的第7位的状态实现对计数与否的控制。
三、资源分配:
1.分支函数程序:A:累加器C:位操作B:做乘方的寄存器DPTR:片外寻址指针2000H、2001H、2002H:片外存储空间
JC DIVI
MOV A,R7
CPL A;对X进行取反
MOV DPTR,#2001H
MOVX @DPTR,A ;存入片外RAM
LJMP STOP
DIVI:MOV B,#2H ;除法子程序
MOV A,R7
DIV AB
MOV DPTR,#2001H
MOVX @DPTR,A
LJMP STOP
MUTI:MOV A,R7 ;平方子程序
相关文档
最新文档