1、单片机的中断是一个很高明的办法。没有中断时单片机只会顺序执行主程序中的语句。
2、单片机的定时器有自己的时钟,打开51单片机的定时器后,单片机一边顺序执行主程序的语句时,一边定时器在计时。当计到你设定的值后,他需要产生中断,然后暂停主程序语句,转到中断程序中执行你的命令。执行完命令后返回到主程序的顺序语句中。然后知道下一次中断来临,再次产生中断。
3、要让他能产生中断,你就必须开中断。这就像一个控制开关,你不把开关打开,灯怎么会亮。
我猜你的串口发送用的是轮询等待发送结束的方式,而数码管动态扫描用的是软件延时(就是for循环)吧?、、
这样串口发送很占时间——你想,如果是9600baud的话,发一字节就要1ms左右。因此这个插入的发送数据的任务会让延时函数的延时时间比预定的长很久,动态扫描就连不起来了。
改善方法有3个:
1,最简单的,在通信可靠的前提下尽可能提高串口波特率,同时降低发送频率(就是增大定时器中断周期),再把要发送的数据弄少点,能用缩写的就别写一大串。。
2,串口发送改为中断方式,这个不细说了,网上有资料。。
3,舍弃数码管扫描的软件延时,改用硬件延时(就是把数码管的位的切换也放在定时器中断里完成),保证动态扫描的及时性。这叫单片机的“前后台”编程方式,相当于将动态扫描放在了“后台”,由定时器中断来触发,不触发则不占CPU时间。
原理很简单,说白了就是用一个计数器对内部时钟计数,计满溢出时触发定时器中断,此时,程序会中断执行当前代码跳转到一个固定地址(定时器中断服务程序入口)去执行中断服务程序,执行完毕再回到被中断的代码地址继续执行。
主程序中:
sbit OUT=P1^0;
uchar a=0;//计中断次数的变量
TMOD=0x01;// 定时器1工作方式一
ET0=1;
EA=1;
TH0=(65536-50000)/256;//定时50ms
TL0=(65536-50000)%256;
TR0=1;//启动定时器
while(1);
中断程序:
void Timer0(void) interrupt 1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
a++;
if(a==10) {a=0;OUT=!OUT;}//中断10次500MS,半个周期
}
以上就是关于51单片机定时的时候为什么一定要打开中断全部的内容,包括:51单片机定时的时候为什么一定要打开中断、51单片机定时中断导致主程序数码管显示出问题、51单片机定时器中断原理等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)