51单片机数码管显示实验报告.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
51 单片机数码管显示实验 实验内容: 1)编写程序让 8 只数码管初始显示 0,每隔大约 1s 加 1 显示(可以用延时函数实现 ),到数 码管显示 9 后,再从 0 开始显示,如此循环反复。 2)C 语言程序 #includereg52.h #define uint unsigned int void display(); void num(); int i; unsigned char code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8, 0x80,0x90,0x88,0x83, 0xc6,0xa1,0x86,0x8e}; // 共阳极数码管 0-F 编码表 void delayms(uint); void main() { while(1) { num(); display(); } } void display() { P2=0xff;// 消隐 P0 连接段选, P1 节位选 P1=0x00;//8 个数码管同时显示 P2=table[i];// 数码管显示数码 0 delayms(1000);// 延时 5ms } void num() { if(i9) i++; else i=0; } void delayms(uint x) { uint i,j; for(i=0;ix;i++) for(j=0;j110;j++); } 3)汇编语言: ORG 0000H LJMP MAIN ORG 0100H ;P2 连接段选, P1 节位选 MAIN: MOV P1,#00H ;所有的数码管都显示 MOV R2,#00H ;从 0 开始显示 LOOP: MOV A,R2 ;为下面的基址加变址寄存器寻址方式做准备 MOV DPTR,#TAB1 ;把数组的首地址赋给 DPTR MOVC A,@A+DPTR ;取数组中的数字 MOV P2,A ;把取得的值送给 P0 口显示 ACALL DELAY ;延时一会 INC R2 ;为取下一个数加一 CJNE R2,#10,LOOP ;只要数小于 10 就继续循环显示 MOV R2,#00H ;如果加到 10 后重新从 0 开始 LJMP LOOP ;进入循环函数 ;****************************************** TAB1: DB 0C0H,0F9H,0A4H,0B0H,99H; 数组 DB 92H,82H,0F8H,80H,90H RET ;****************************************** DELAY: MOV R3,#3 ;延时函数 DE1: MOV R4,#0FFH DE2: MOV R5,#0FFH DJNZ R5,$ DJNZ R4,DE2 DJNZ R3,DE1 RET ;************************************************* END (3)编写程序学习数码管的动态显示,让8 只数码管从从左往右显示 1、2、3? ? 8。 C 语言程序: #includereg52.h #define uint unsigned int unsigned char code table[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8, 0x80,0x90,0x88,0x83, 0xc6,0xa1,0x86,0x8e}; // 共阳极数码管 0-F 编码表 void delayms(uint x); void zuoyi(); void main() { int i; while(1) { P1=0xfe; for(i=0;i8;i++) { P2=table[i]; delayms(3); zuoyi(); } } } void delayms(uint x) { uint i,j; for(i=0;ix;i++) for(j=0;j110;j++); } void zuoyi() { int a; a=~P1; a=a1; P1=~a; } 汇编语言: ;数码管动态显示 ORG 0000H LJMP MAIN ORG 0100H ;P0 连接段选, P1 节位选 MAIN: MOV R2,#0 ;从 0 开始显示 MOV P1,#0FEH LOOP: MOV A,R2 MOV DPTR,#TAB1 MOVC A,@A+DPTR MOV P2,A ACALL DELAY INC R2 MOV A,P1 RL A MOV P1,A CJNE R2,#8,LOOP MOV R2,#0 AJMP LOOP ;***************************************

文档评论(0)

5566www + 关注
实名认证
文档贡献者

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

版权声明书
用户编号:6122115144000002

1亿VIP精品文档

相关文档