分支和循环程序设计_第1页
分支和循环程序设计_第2页
分支和循环程序设计_第3页
分支和循环程序设计_第4页
分支和循环程序设计_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

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

文档简介

...wd......wd......wd...实验名称分支与循环程序设计成绩指导教师******专业班级******姓名白***学号*******联系********一、任务要求熟练掌握Keil环境下汇编语言程序的调试方法,加深对汇编语言指令、机器码、寻址方式等基本内容的理解,掌握分支程序和简单程序的设计与调试方法,了解并行IO口的使用。设有8bits符号数X存于外部RAM单元,按以下方式计算后的结果Y也存于外部RAM单元,请按要求编写完整程序。利用51系列单片机设计一个24小时制电子时钟,电子时钟的时、分、秒数值分别通过P0、P1、P2端口输出〔以压缩BCD码的形式〕。P3.0为低电平时开场计时,为高电平时停顿计时。设计1s延时子程序〔延时误差小于10us,晶振频率12MHz〕。1〕实现4位十进制加、减1计数,千位、百位由P1口输出;十位、个位由P2口输出。利用P3.7状态选择加、减计数方式。2〕利用P3口低四位状态控制开场和停顿计数,控制方式自定。二、设计思路先在外部RAM取数,然后判断该符号数是否为负数,假设为负数,那么取相反数并存数;假设为正数,那么接着判断该数是否大于等于64,假设满足,那么求平方并存数,先存低位,后存高位;假设小于64,那么接着判断该数是否大于10,假设满足,那么求该数的一半并存数;假设小于等于10,那么取相反数并存数。第一步先编可以延时1S的子程序DELAY;接着判断P3.O是否满足开场计数条件,假设不满足,那么重复判断;假设满足,那么对时分秒分别赋值,调用延时子程序,判断是否满足计时条件,假设不满足,那么重复判断直至满足;假设满足,那么秒钟自加一,循环,判断秒钟循环满60次后出循环,对分钟自加一,然后继续循环,最后判断分钟循环满60次后出循环,对时钟自加一,然后判断时钟循环满24那么回到初值,时分秒重新赋值并重新开场循环。判断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 ORG1000HSTART:MOVDPTR,#2000H;地址指针赋初值MOVA,#22 MOVX@DPTR,AMOVXA,@DPTR;取数 JBACC.7,DD CJNEA,#64,AA;假设A≠64,那么转AAAA:JCBB;假设A<64,那么转BBMOVB,A MULAB;求A的平方 INCDPTR MOVX@DPTR,A;存结果低八位 INCDPTR MOVA,B MOVX@DPTR,A;存结果高八位 SJMP$BB:CJNEA,#10,CC;假设A≠10,那么转CCCPLAEE: INCDPTR MOVX@DPTR,A SJMP$CC:JCDD;假设A<10,那么转DDRRA;假设A>10,那么右移一位 SJMPEEDD:CPLAINCASJMPEE END2.时钟设计ORG0000HLJMPSTARTORG1000HSTART:JBP3.0,START;假设为0,那么开场计时RESTA:MOVR3,#24 MOVP0,#00H;时钟赋初值LOOP3:MOVR4,#60MOVP1,#00H;分钟赋初值LOOP2:MOVR5,#60MOVP2,#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;判断时钟是否完毕循环 LJMPRESTADELAY:MOVR0,#12NOPDELAY3:MOVR1,#130DELAY2:MOVR2,#212 NOP NOPDELAY1:NOP DJNZR2,DELAY1 DJNZR1,DELAY2 DJNZR0,DELAY3 RET END3.十进制加减计数器 ORG0000HLJMPSTARTORG1000HSTART:MOVP1,#12HMOVP2,#92HLOOP:ACALLDELAY MOVA,P2 JBP3.7,AA;假设为1,那么转AA实现记数加1 ADDA,#99H DAA;实现十进制减1 MOVP2,A JCBB;判断是否产生借位,假设产生,那么对高位减1 MOVA,P1 ADDA,#99H DAA MOVP1,A AJMPLOOPAA:ADDA,#01H DAA;实现十进制加1 MOVP2,A JNCBB;判断是否产生进位,假设产生,那么对高位加1 MOVA,P1 ADDA,#01H DAA MOVP1,ABB: AJMPLOOPDELAY:MOVR0,#12NOPDELAY3:MOVR1,#130DELAY2:MOVR2,#212 NOP NOPDELAY1:NOP DJNZR2,DELAY1 DJNZR1,DELAY2 DJNZR0,DELAY3 RET END六、程序测试方法与结果1.8bit符号数的判断与计算1〕令片外RAM中数据为642〕令片外RAM中数据为223〕令片外RAM数据为14〕令片外RAM数据为-22.时钟设计1〕令P3.0=0,程序按十进制正常运行2〕令P3.0=0,暂停计数3〕设置断点观察延时子程序的延时时间,刚好为1s3.十进制加减1计数器1〕将P3.7置1,计数器实现加一计数2〕将P3.7置0,计数器实现减一计数七、思考题实现多分支构造程序的主要方法有哪些举例说明。分支地址表法转移指令表法地址偏移量表法在编程上,十进制加1计数器与十六进制加1计数器的区别是什么怎样用十进制加法指令实现减1计数十进制加1计数器满十进1,十六进制加1计数器满16进1,十进制加法需用DAA指令进展调整用ADDA,#99HDAA指令,即可实

温馨提示

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

评论

0/150

提交评论