自己刚学单片机的时候写的一个电子表的程序。

#include<reg51.h>
#define uint unsigned int
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
uchar code t[]={
0xed,0x48,0xf4,
0xb5,0xb5,0x99,
0x3d,0x7d,0x7d,0x85,
0xfd,0xbd
};
void dely(uint);
void disp(uchar,uchar,uchar,uchar,uchar,uchar);
uchar num,num1,num2,num3,shi1,shi2,fen1,fen2,miao1,miao2;
void main()
{
TMOD=0x11;
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
EA=1;ET0=1;TR0=1;
while(1)
 {
 disp(shi1,shi2,fen1,fen2,miao1,miao2);
 }
}
void dely(uint x)
{
 uint i,j;
 for(i=x;i>0;i--)
  for(j=110;j>0;j--);
}
void disp(uchar shi1,uchar shi2,uchar fen1,uchar fen2,uchar miao1,uchar miao2)
{
 dula=1;

P0=t[shi1];

dula=0;

P0=0xff;
 wela=1;

P0=0x1f;

wela=0;

dely(5);


 dula=1;

P0=t[shi2];

dula=0;

P0=0xff;
 wela=1;

P0=0x2f;

wela=0;

dely(5);


 dula=1;

P0=t[fen1];

dula=0;

P0=0xff;
 wela=1;

P0=0x37;

wela=0;

dely(5);


 dula=1;

P0=t[fen2];

dula=0;

P0=0xff;
 wela=1;

P0=0x3b;

wela=0;

dely(5);


 dula=1;

P0=t[miao1];

dula=0;

P0=0xff;
 wela=1;

P0=0x3d;

wela=0;

dely(5);


 dula=1;

P0=t[miao2];

dula=0;

P0=0xff;
 wela=1;

P0=0x3e;

wela=0;

dely(5);
}
void ZD() interrupt 1
{
 TH0=(65536-45872)/256;
 TL0= (65536-45872)%256;
 num++;
 if(num==20)
 {
  num=0;
  num1++;
  miao2=num1%10;miao1=num1/10;
  if(num1==60){
   num1=0;
   num2++;
   }
  fen1=num2/10;
  fen2=num2%10;
  if(num2==60){
   num2=0;
   num3++;
   }
  shi1=num3/10;
  shi2=num3%10;
  if(num3==60)
   num3=0;
 }

   
用一个中断来写的。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值