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

下载本文档

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

文档简介

1、实验名称 分支与循环程序设计 成 绩 指导教师 * 专业班级 * 姓 名 白* 学 号 * 联系 * 一、任务要求1. 熟练掌握Keil环境下汇编语言程序的调试方法,加深对汇编语言指令、机器码、寻址方式等根本内容的理解,掌握分支程序和简单程序的设计与调试方法,了解并行IO口的使用。2. 设有8bits符号数X存于外部RAM单元,按以下方式计算后的结果Y也存于外部RAM单元,请按要求编写完整程序。 3. 利用51系列单片机设计一个24小时制电子时钟,电子时钟的时、分、秒数值分别通过P0、P1、P2端口输出以压缩BCD码的形式。P3.0为低电平时开始计时,为高电平时停止计时。设计1s延时子程序延时

2、误差小于10us,晶振频率12MHz。4. 1实现4位十进制加、减1计数,千位、百位由P1口输出;十位、个位由P2口输出。利用P3.7状态选择加、减计数方式。2利用P3口低四位状态控制开始和停止计数,控制方式自定。二、设计思路1. 先在外部RAM取数,然后判断该符号数是否为负数,假设为负数,那么取相反数并存数;假设为正数,那么接着判断该数是否大于等于64,假设满足,那么求平方并存数,先存低位,后存高位;假设小于64,那么接着判断该数是否大于10,假设满足,那么求该数的一半并存数;假设小于等于10,那么取相反数并存数。2. 第一步先编可以延时1S的子程序DELAY;接着判断P3.O是否满足开始计

3、数条件,假设不满足,那么重复判断;假设满足,那么对时分秒分别赋值,调用延时子程序,判断是否满足计时条件,假设不满足,那么重复判断直至满足;假设满足,那么秒钟自加一,循环,判断秒钟循环满60次后出循环,对分钟自加一,然后继续循环,最后判断分钟循环满60次后出循环,对时钟自加一,然后判断时钟循环满24那么回到初值,时分秒重新赋值并重新开始循环。3. 判断P3.7,假设为1,那么进行加一计数,假设为0,那么跳转至另一程序进行减一计数;加一计数中,先取低位P1送A,自加一,送P1,判断是否有溢出,假设有,那么取高位P2送A,自加一,送P2,然后回判断循环;减一计数同理,即先取低位P1送A,自减一,送P

4、1,判断是否有进位,假设有,那么取高位P2送A,自减一,送P2,然后回判断继续循环。三、资源分配12000H 片外RAM存数 2001H 存结果低八位 2002H 存结果高八位 B存放器 暂存结果高八位2P3.0 存计时判断位 R0、R1、R2 存延时子程序中各重循环的循环次数 R3、R4、R5 存时分秒的循环次数 P0、P1、P2 存时分秒的输出值3P1、P2 分别存十进制计数的低两位、高两位 P3.7 存计数方式的控制位四、流程图1、8 bit符号数的判断与计算 2、时钟设计 3十进制加减一计数器 五、源代码 含文件头说明、语句行注释18 bit符号数的判断与计算 ORG 0000HLJM

5、P STARTORG 1000HSTART: MOV DPTR,#2000H;地址指针赋初值 MOV A,#22MOVX DPTR,A MOVX A,DPTR;取数JB ACC.7,DDCJNE A,#64,AA;假设A64,那么转AAAA: JC BB;假设A64,那么转BB MOV B,AMUL AB;求A的平方INC DPTRMOVX DPTR,A;存结果低八位INC DPTRMOV A,BMOVX DPTR,A;存结果高八位SJMP $BB: CJNE A,#10,CC;假设A10,那么转CC CPL AEE: INC DPTR MOVX DPTR,ASJMP $CC: JC DD;假

6、设A10,那么转DD RR A;假设A10,那么右移一位SJMP EEDD: CPL A INC A SJMP EEEND2时钟设计 ORG 0000H LJMP START ORG 1000HSTART: JB P3.0,START;假设为0,那么开始计时RESTA: MOV R3,#24 MOV P0,#00H ;时钟赋初值LOOP3: MOV R4,#60 MOV P1,#00H ;分钟赋初值LOOP2: MOV R5,#60 MOV P2,#00H ;秒钟赋初值LOOP1: ACALL DELAY;调用延时1S子程序LOOP: JB P3.0,LOOP;假设为1,那么停止计时 MOV

7、A,P2 ADD A,#01H DA A MOV P2,A DJNZ R5,LOOP1;判断秒钟是否结束循环 MOV A,P1 ADD A,#01H DA A MOV P1,A DJNZ R4,LOOP2;判断分钟是否结束循环 MOV A,P0 ADD A,#01H DA A MOV P0,A DJNZ R3,LOOP3;判断时钟是否结束循环 LJMP RESTADELAY: MOV R0,#12 NOPDELAY3:MOV R1,#130DELAY2:MOV R2,#212 NOP NOPDELAY1:NOP DJNZ R2,DELAY1 DJNZ R1,DELAY2 DJNZ R0,DEL

8、AY3 RET END3十进制加减计数器 ORG 0000H LJMP START ORG 1000HSTART:MOV P1,#12H MOV P2,#92HLOOP: ACALL DELAY MOV A,P2 JB P3.7,AA;假设为1,那么转AA实现记数加1 ADD A,#99H DA A;实现十进制减1 MOV P2,A JC BB;判断是否产生借位,假设产生,那么对高位减1 MOV A,P1 ADD A,#99H DA A MOV P1,A AJMP LOOPAA: ADD A,#01H DA A;实现十进制加1 MOV P2,A JNC BB;判断是否产生进位,假设产生,那么对

9、高位加1 MOV A,P1 ADD A,#01H DA A MOV P1,ABB: AJMP LOOPDELAY: MOV R0,#12 NOPDELAY3:MOV R1,#130DELAY2:MOV R2,#212 NOP NOPDELAY1:NOP DJNZ R2,DELAY1 DJNZ R1,DELAY2 DJNZ R0,DELAY3 RET END六、程序测试方法与结果18 bit符号数的判断与计算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 实现多分支结构程序的主要方法有哪些?举例说明。a) 分支地址表法b) 转移指令表法c) 地址偏移量表法2 在编程上,十进制加1计数器与十六进制加1计数器的区别是什么?怎样用十进制加法指令实现减1计数?a) 十进制加1计数器满十进1,十六进制加1计数器满16进1,十进制加法需用DA A指令进行调整b) 用ADD A,#99HDA A 指令,即可实现减1计数

温馨提示

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

评论

0/150

提交评论