定时器资料.ppt

TH0 = 0x3C; TL0 = 0xB0; TR0 = 1; While(1); } void Timer0_ISR( ) interrupt 1 //定时器0中断服务函数 { TH0 = 0x3C; TL0= 0xB0; temp= _crol_ (temp,1); P1 = temp; } void INT0_ISR( ) interrupt 0 using 1 //外部中断0中断服务函数 { unsigned char i,sel; sel = 0xff; for(i=0;i16;i++) { P1 = sel; sel = ~ sel; delay(50000); } } 【例5.3】利用T0的方式1产生频率为50Hz、占空比为50%的方波,由P1.0输出。假定CPU使用中断方式进行控制。仍采用6MHz的晶体。 分析:方波频率是50Hz,周期为20ms。由于占空比为50%,高电平部分和低电平部分所占时间都为方波周期的一半(10ms)。因此定时时间可设置为10ms。由于晶振6M, 1机器周期 2 ?S,那么初值: X = 65536-10000 / 2 = 60536 = EC78H 可编程如下: #include reg51.h sbit P1_0 = P1^0; void main ( void ) //主函数 { TMOD = 0x01; TH0 = 0xEC; TL0 = 0x78; EA = 1; ET0 = 1; TR0 = 1; while(1); } void timer0_int(void)interrupt 1//定时器0中断函数 { P1_0 = !P1_0;} 【例5.4】利用T0的方式1产生一个50Hz、占空比为25%的方波,由P1.0输出。假定CPU用查询方式进行控制。仍采用6MHz的晶体。 分析:方波频率是50Hz,周期为20ms。由于占空比为25%,则一个周期中高电平时间为5ms,低电平时间为15ms。因此定时初值有两个: X1= 65536-5000/2 =63036 = F63CH X2= 65536-15000/2 =58036= E2B4H 采用查询方式来控制,就必须要知道单片机根据什么知道定时时间是否到了。因为在计数满时,会将TF0置1,这是不以人的意志为转移的。采用中断方式时,是通过硬件检测TF0为1后自动进入中断服务程序。采用查询方式时,可通过软件查询TF0标志是否为1来可以判断定时时间是否到了。 由于仅使用查询方式,不开中断,T0定时时间到时,TF0标志出现,但不会进入中断服务,所以要人工用指令清除TF0标志。 程序如下: #include reg51.h sbit P1_0 = P1^0; void main ( void ) //主函数 { TMOD = 0x01; TR0 = 1; for(;;) { TH0 = 0xF6; TL0 = 0x3C; P1_0 = 1; while(TF0 = = 0); TF0 = 0; TH0 = 0xE2; TL0 = 0xB4; P1_0 = 0; while(TF0 = = 0); TF0 = 0; } } 【例5.5 】(T5_3)设定时器T0工作于方式2,产生500?s定时中断,在中断服务程序中将累加器A的内容减1,并送P1口显示。已知晶振频率为6MHZ。 时间常数为:28 – 500 / 2=6=06H。 #include reg51.h unsigned char data temp _at_ 0x30; void main ( void ) //主函数 { TMOD = 0x02; TH0 = 0x06; TL0 = 0x06; EA = 1; ET0 = 1; TR0 = 1; while(1); } void timer0_int(void)interrupt 1//定时器0中断函数 { temp=temp-1;} 看一看这个程序和前面的程序有什么不同的地方。前面的在中断服务程序中有给TL0、TH0重新赋值的过程,在本例中没有。这是因为【例6-5-2】中采用的是方式1,不具备本例中方式2的“自动再装入功能”。既然没有这种功能,只有人工进行,否则在第一次计数溢出后就会从0开始重新计数。导致后面的定时时间和第一次不一样,不再是10ms,而是最大的定时时间。 【例5.6】将任务4扩展一下,将图4.1所表示的单脉冲电路的负脉冲端接在单片机的P3.4引脚。编写程序,使每按

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档