51单片机T0定时器应用1

发布者:LuckyDaisy最新更新时间:2017-12-31 来源: eefocus关键字:51单片机  定时器 手机看文章 扫描二维码
随时随地手机看文章

1.实验任务
  用AT89S51单片机的定时/计数器T0产生一秒的定时时间,作为秒计数时间,当一秒产生时,秒计数加1,秒计数到60时,自动从0开始。硬件电路如下图所示
2.电路原理图
定时计数器T0作定时应用技术(一)
图4.15.1
3.系统板上硬件连线
(1).把“单片机系统”区域中的P0.0/AD0-P0.7/AD7端口用8芯排线连接到“四路静态数码显示模块”区域中的任一个a-h端口上;要求:P0.0/AD0对应着a,P0.1/AD1对应着b,……,P0.7/AD7对应着h。
(2).把“单片机系统”区域中的P2.0/A8-P2.7/A15端口用8芯排线连接到“四路静态数码显示模块”区域中的任一个a-h端口上;要求:P2.0/A8对应着a,P2.1/A9对应着b,……,P2.7/A15对应着h。
4.程序设计内容
  AT89S51单片机的内部16位定时/计数器是一个可编程定时/计数器,它既可以工作在13位定时方式,也可以工作在16位定时方式和8位定时方式。只要通过设置特殊功能寄存器TMOD,即可完成。定时/计数器何时工作也是通过软件来设定TCON特殊功能寄存器来完成的。
  现在我们选择16位定时工作方式,对于T0来说,最大定时也只有65536us,即65.536ms,无法达到我们所需要的1秒的定时,因此,我们必须通过软件来处理这个问题,假设我们取T0的最大定时为50ms,即要定时1秒需要经过20次的50ms的定时。对于这20次我们就可以采用软件的方法来统计了。
  因此,我们设定TMOD=00000001B,即TMOD=01H
  下面我们要给T0定时/计数器的TH0,TL0装入预置初值,通过下面的公式可以计算出
TH0=(216-50000) / 256
TL0=(216-50000) MOD 256
  当T0在工作的时候,我们如何得知50ms的定时时间已到,这回我们通过检测TCON特殊功能寄存器中的TF0标志位,如果TF0=1表示定时时间已到。
5.程序

定时计数器T0作定时应用技术(一)
图4.15.2
6.汇编源程序(查询法)
SECOND            EQU 30H
TCOUNT           EQU 31H
                            ORG 00H
START:               MOV SECOND,#00H
                           MOV TCOUNT,#00H
                            MOV TMOD,#01H
                            MOV TH0,#(65536-50000) / 256
                           MOV TL0,#(65536-50000) MOD 256
                            SETB TR0
DISP:                  MOV A,SECOND
                            MOV B,#10
                           DIV AB
                            MOV DPTR,#TABLE
                            MOVC A,@A+DPTR
                           MOV P0,A
                            MOV A,B
                            MOVC A,@A+DPTR
                           MOV P2,A
WAIT:                 JNB TF0,WAIT
                            CLR TF0
                            MOV TH0,#(65536-50000) / 256
                           MOV TL0,#(65536-50000) MOD 256
                            INC TCOUNT
                            MOV A,TCOUNT
                           CJNE A,#20,NEXT
                            MOV TCOUNT,#00H
                            INC SECOND
                           MOV A,SECOND
                            CJNE A,#60,NEX
                           MOV SECOND,#00H
NEX:                   LJMP DISP
NEXT:                LJMP WAIT
TABLE:              DB 3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,6FH
                            END
7.C语言源程序(查询法)
#include
unsigned char code dispcode[]={0x3f,0x06,0x5b,0x4f,
                               0x66,0x6d,0x7d,0x07,
                               0x7f,0x6f,0x77,0x7c,
                               0x39,0x5e,0x79,0x71,0x00};
unsigned char second;
unsigned char tcount;
void main(void)
{
  TMOD=0x01;
  TH0=(65536-50000)/256;
  TL0=(65536-50000)%6;
  TR0=1;
  tcount=0;
  second=0;
  P0=dispcode[second/10];
  P2=dispcode[second];
  while(1)
    {
      if(TF0==1)
        {
          tcount++;
          if(tcount==20)
            {
              tcount=0;
              second++;
              if(second==60)
                {
                  second=0;
                }
              P0=dispcode[second/10];
              P2=dispcode[second];             
            }
          TF0=0;
          TH0=(65536-50000)/256;
          TL0=(65536-50000)%6;
        }
    }
}
8.汇编源程序(中断法)
SECOND                     EQU 30H
TCOUNT                    EQU 31H
                                     ORG 00H
                                     LJMP START
                                     ORG 0BH
                                     LJMP INT0X
START:                        MOV SECOND,#00H
                                     MOV A,SECOND
                                     MOV B,#10
                                     DIV AB
                                     MOV DPTR,#TABLE
                                     MOVC A,@A+DPTR
                                     MOV P0,A
                                     MOV A,B
                                     MOVC A,@A+DPTR
                                     MOV P2,A
                                     MOV TCOUNT,#00H
                                     MOV TMOD,#01H
                                     MOV TH0,#(65536-50000) / 256
                                     MOV TL0,#(65536-50000) MOD 256
                                     SETB TR0
                                     SETB ET0
                                     SETB EA
                                     SJMP $
INT0X:
                                     MOV TH0,#(65536-50000) / 256
                                     MOV TL0,#(65536-50000) MOD 256
                                     INC TCOUNT
                                     MOV A,TCOUNT
                                     CJNE A,#20,NEXT
                                     MOV TCOUNT,#00H
                                     INC SECOND
                                     MOV A,SECOND
                                     CJNE A,#60,NEX
                                     MOV SECOND,#00H
NEX:                                     MOV A,SECOND
                                     MOV B,#10
                                     DIV AB
                                     MOV DPTR,#TABLE
                                     MOVC A,@A+DPTR
                                     MOV P0,A
                                     MOV A,B
                                     MOVC A,@A+DPTR
                                     MOV P2,A
NEXT:                          RETI
                  
TABLE:                        DB 3FH,06H,5BH,4FH,66H,6DH,7DH,07H,7FH,6FH
                                     END
9.C语言源程序(中断法)
#include
unsigned char code dispcode[]={0x3f,0x06,0x5b,0x4f,
                               0x66,0x6d,0x7d,0x07,
                               0x7f,0x6f,0x77,0x7c,
                               0x39,0x5e,0x79,0x71,0x00};
unsigned char second;
unsigned char tcount;
void main(void)
{
  TMOD=0x01;
  TH0=(65536-50000)/256;
  TL0=(65536-50000)%6;
  TR0=1;
  ET0=1;
  EA=1;
  tcount=0;
  second=0;
  P0=dispcode[second/10];
  P2=dispcode[second];
  while(1);
}
void t0(void) interrupt 1 using 0
{
  tcount++;
  if(tcount==20)
    {
      tcount=0;
      second++;
      if(second==60)
        {
          second=0;
        }
      P0=dispcode[second/10];
      P2=dispcode[second];             
    }
  TH0=(65536-50000)/256;
  TL0=(65536-50000)%6;
}

关键字:51单片机  定时器 引用地址:51单片机T0定时器应用1

上一篇:51单片机4*4键盘的程序设计方法
下一篇:基于51单片机的99秒马表设计

推荐阅读最新更新时间:2024-03-16 15:51

51单片机汇编语言实验(六)-----8255键盘与显示设计
一、实验目的:    掌握8255外接键盘与数码管显示的设计 二、实验设备:    PC计算机一台,Dais-52PRO+实验系统一套。 三、实验内容:    8255键盘与显示设计 四、 8255键盘与显示设计    1、实验原理:    本实验使用8255的PA7到PA0控制数码管字形口、PB5到PB0控制数码管字位口,同时PB4到PB0作为键盘扫描口、PC3~PC0作为键盘读入口。利用CPU控制8255,对4×5键盘进行扫描和键值读取,将键值显示到6位数码管上。本文介绍的是简化版的实验,不控制最后一列键盘,数码管位选端不接线,直接点亮。    2、实验步骤:   ① 按下图拆除14芯扁平电缆;   ②将8
[单片机]
<font color='red'>51单片机</font>汇编语言实验(六)-----8255键盘与显示设计
51单片机PWM程序详解
#include reg51.h //程序是基于KEIL-C51编写,引入8051头文件 sbit P10=P1^0; sbit P11=P1^1; unsigned int scale; //占空比控制变量 void main(void) { unsigned int n; //延时循环变量 TMOD=0x02; //定时器0,工作模式2(0000 0010),8位定时 TH0=0x06; //定时250us(12M晶振) TL0=0x06; //预置值 TR0=1; //启动定时器0 ET0=1; //启动定时器0中断 EA=1;
[单片机]
<font color='red'>51单片机</font>PWM程序详解
lpc1114通用定时器-定时功能
下面我们以LED流水灯为例演示定时功能,流水的时间间隔由定时器精确控制。(看了上面的这句话就绕道的童鞋,请不要急着走,接下来讲的不是怎么实现流水灯,而是怎么样定时。) 下面我们以16位定时器0来演示。 新建一个工程,如下图所示: 在timer.h文件中,输入以下代码: #ifndef __NXPLPC11xx_TIME_H__ #define __NXPLPC11xx_TIME_H__ extern void T16B0_init(void); extern void T16B0_delay_ms(uint16_t ms); extern void T16B0_delay_us(uint16_t us); #
[单片机]
lpc1114通用<font color='red'>定时器</font>-定时功能
STM32F4——定时器原理及应用中断、输入捕获、PWM输出
一、简介: 不同的STM32系列有不同数量的定时器,针对现在学习的STM32F40x系列总共有14个定时器,针对这14个定时器可以将其分为3类,高级定时器、通用定时器和基本定时器,三种定时器大同小异,下边会针对通用定时器来介绍定时器的原理和应用。对于通用定时器根据位数和计数方式的不同又可以分为3类,相关分类的图表如下: 二、应用: 1、更新:计数器的上溢或下溢。2、事件触发。3、输入捕获。4、输出比较。5、支持针对定位的增量编码和霍尔传感器电路。5、触发输入作为外部时钟或按周期电源管理。下边会针对部分应用做相关介绍和代码分析。 三、框图: 下图是通用定时器TIM2~TIM5的框图,其他定时器的框图和该框图是
[单片机]
STM32F4——<font color='red'>定时器</font>原理及应用中断、输入捕获、PWM输出
STM32CubeMX学习:基本定时器
先看基本定時器框图: 比如用cube配置Time14的時候, 得先确定时钟频率,这个可以查看数据手册或者查看代码可以知道TIM14是挂接到APB1时钟线上。 预分频器设置为108-1,即108分频,最后定时器的频率为1000 000HZ。一个脉冲的时间为1/1000 000s。 而计数周期为2500(自动重载寄存器),2500次记一次,则周期时间大致为1/400s,即400HZ。 若要定时1秒,则计数周期为1000 000即可 或将预分频加大,则计数周期会变小。
[单片机]
STM32CubeMX学习:基本<font color='red'>定时器</font>
中断及定时器实现时钟功能
中断及定时器实现24时 时钟,程序如下: #include reg52.h #define PORTLEN P0 sbit bit_select = P2^0; sbit seg_select = P2^1; unsigned char src = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71}; unsigned char qrc = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; unsigned char second1 ; unsigned char shi
[单片机]
51单片机用C语言实现精确延时的程序
在晶振11.0592下实现15 s的延时: for ( i=0; i 3; i++); 延时程序 (在11.0592的晶振下调用本函数需24 s,每次计数需16 s) void delay( int useconds){ int s; for (s=0; s useconds; s++); } 若需要延时的时间为480 s,那么useconds的数值取值为: (480-24)/ 16 = 28.5 ,取29
[单片机]
基于C语言51单片机电子密码锁的设计与仿真
  0、引言   电子密码锁是现代生活中常用的加密工具。它克服了机械式密码锁密码量少、安全性能差的缺点,尤其是的智能电子密码锁;不仅具有电子密码锁的功能”还可引人智能化管理功能,从而使密码锁具有更离的安全性和可靠性。   电子密码锁通常使用ARM和单片机控制,单片机相对ARM实现较为简单,功能较为完善,因此使用单片机控制较多。用单片机控制的窖码锁常使用汇编语言编写程序,显示器多数用。而本文所介绍的电子密犸锁使用移植性及可读性强的高级语言C语言编写,便于修改和增减功能蚤同时采用显示清楚数码管,功率消耗小而且寿命长的 液晶显示器,显示更加直观,使用更加方便。从经济实用的角度出发,采用STC89C52单片机设计出一种具有密码设置、报
[单片机]
基于C语言<font color='red'>51单片机</font>电子密码锁的设计与仿真
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved