前几天用STC89C52单片机制作了一个电子时钟,经过一段时间的实验,发现时间精度存在误差,一分钟慢4秒左右。
这可了不得,十分钟就要慢40秒,一天下来不得慢半96分钟!!!
这个单片机晶振频率为11.0592mhz,和大部分时钟的晶振频率相同,应该没有问题。
后天考虑到源代码:
在定时器中断函数里:
void t0(void) interrupt 1 using 0
{
tcount++;
if(tcount==4000)
{tcount=0;
second++;
if(second==60)
{second=0;
minute++;
if(minute==60)
{minute=0;
hour++;
if(hour==24)
{hour=0;
}
}
}
P1=~P1;
}
}
interrupt 后面的数字简单的说就是中断服务函数的代号
0代表外中断0
1代表定时计数器0中断
2代表外中断1
3代表定时计数器1中断
4代表串行口中断
所以interrupt 1代表定时计数器产生中断后就转到这个函数里面执行。
代码其实还挺简单,每中断4000下将产生1秒。
等等...
每4000下的中断为1秒,那么原因很有可能在这里。
试着将tcount==3600,和秒表对比发现竟然每一分钟快了1秒左右。
bingo!问题的确出在tcount的取值上面,将tcount的数值改为3700,和秒表对比发现,秒数没有误差,有误差的应该就是毫秒级吧。
void t0(void) interrupt 1 using 0
{
tcount++;
if(tcount==3700)
{tcount=0;
second++;
if(second==60)
{second=0;
minute++;
if(minute==60)
{minute=0;
hour++;
if(hour==24)
{hour=0;
}
}
}
P1=~P1;
}
}
这样就解决了时钟精度的问题。
相关文章
data:image/s3,"s3://crabby-images/b813e/b813e0e49a842833bda2089afc9069c16f544632" alt=""
data:image/s3,"s3://crabby-images/9dda6/9dda6c351ee0936a6ab17a900a85d237479b6308" alt=""
data:image/s3,"s3://crabby-images/d8651/d8651b610c022617ced508638a0d820df1c4dde1" alt=""
data:image/s3,"s3://crabby-images/2ec62/2ec62c96ab4a792abcdbbe77bc57c899e698ce88" alt=""
data:image/s3,"s3://crabby-images/ef7a2/ef7a26e996716314a30def9bbb444a0fd3fa24a1" alt=""
data:image/s3,"s3://crabby-images/0eece/0eece5380d612963e58b4d3085a1c596d915f35e" alt=""
data:image/s3,"s3://crabby-images/83256/8325612908cd7d953412664709bbfb42e611ef98" alt=""
data:image/s3,"s3://crabby-images/492f9/492f9f4ed4cae8acde3f1dea61ed3c9a38827462" alt=""
data:image/s3,"s3://crabby-images/19af8/19af8bbce989329dd9a38f4304e4c3a19e0877da" alt=""
data:image/s3,"s3://crabby-images/b64d1/b64d139fbe51c182f55f095fdd73f0f806aca266" alt=""