分支程序设计实验-单片机第二次试验.doc

分支程序设计实验-单片机第二次试验.doc

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
分支程序设计实验-单片机第二次试验

一、任务要求 1. 设有8bits符号数X存于外部RAM单元,按以下方式计算后的结果Y也存于外部RAM单元,请按要求编写程序。 2. 利用51系列单片机设计一个24小时制电子时钟,电子时钟的时、分、秒数值分别通过P0、P1、P2端口输出(以压缩BCD码的形式)。P3.0为低电平时开始计时,为高电平时停止计时。 提高部分(选做): a. 实现4位十进制加、减1计数,千位、百位由P1口输出;十位、个位由P2口输出。利用P3.7状态选择加、减计数方式。 b. 利用P3口低四位状态控制开始和停止计数,控制方式自定。 二、设计思路 1. 将8bits符号数从外部RAM单元取出至A中,符号位为1的时候为负数,进行取反运算;当符号位为0的时候为正数,因此将A与20进行比较,当A≤20时跳至取反运算那一步;当A>20时将A与40进行比较,如果当A≥40时则对其进行平方运算那一步,当A<40时则进行除法运算那一步。每次算完之后直接储存,最后再分配储存于外部RAM单元的指定位置。 2. 清零R0~R2和P0~P2,开始先判断控制位P3.0是不是0,当P3.0=1时原地踏步重复判断,当P3.0=0时开始运行程序。计时开始,进行秒钟R0计数,每次计数完成用BCD码子程序转换,然后判断计数后R0值是否到60,若R0的值不足60,就直接输出给P2,若R0的值为60,就把R0和P2进行清零后,开始分钟计数部分。同理,每次分钟计数完之后用BCD码子程序转换,然后判断计数后R1的值是否为60,若不为60,就直接输出给P1,若R1的值为60,就把R1和P1清零后开始时钟计数部分。时钟计数完后同样用BCD码子程序转换,然后判断计数后的R2的值是否为24,若不为24,就直接输出给P0,若R2为24,就把R2和P0清零后直接跳出计数部分,从判断P3.0部分再开始.每两次计数输出之间穿插一个1s的延时程序。就可以达到时钟的功能。 三、资源分配 1.分支程序: 数据指针 DPTR:对片外RAM进行读写操作 2000H:存放8bits符号数X 2010H:存放结果Y(取反后的数,或者平方后的高8位,或者除法后的商) 2011H:存放结果Y(平方后的低8位,或者除法后的余数) 2.时钟程序: R0、R1、R2:分别进行秒钟,分钟,时钟的计数 P2、P1、P0:分别输出秒钟,分钟,时钟 P3.0:是否计数的控制位 R3、R4、R5:为1s延时程序指定循环次数 B:BCD码转换子程序的操作数 四、流程图 1.分支程序流程图: 2.时钟程序的流程图: 五、源代码 (含文件头说明、语句行注释) 1.分支程序代码如下: ORG 0000H SJMP START START: MOV DPTR, #2000H MOV A, #31 MOVX @DPTR, A ; 存数 MOV B, 0 ; 寄存器B清零 MOVX A,@DPTR ; 从R0中取出数x JNB ACC.7, COMP1 ; 判断符号位,符号位为0时转到COMP1 LP3: CPL A ; 对x取反 SJMP STORE COMP1: CJNE A, #20, COMP2 ; A≠20时,转到COMP2 SJMP LP3 ; A=20时,转到LP3取反 COMP2: JC LP3 ;C=1,A<20,转到LP3取反 CJNE A,#40,COMP3 ;C=0,A>20.当A≠40时,转到COMP3 LP1: MOV B,A ;A=40时,给B赋值为A MUL AB ;计算x平方 SJMP STORE COMP3: JNC LP1 ;C=0,A>40,转到LP1计

文档评论(0)

didala + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档