datasheet

51单片机的中断与定时计数器尝试

2018-07-12来源: eefocus 关键字:51单片机  中断  定时计数器

这是我的第一篇有关51单片机的博客,主要记录我的学习历程与中间遇到的问题,如有错漏请指出。

在我理解里面中断定时计数器是这样的:

中断是通过检查P3.2(INT0)与P3.3(INT1)两个引脚来触发的

计数器是通过检查P3.4(T0)与P3.5(T1)两个引脚的状态,要达到一定的次数(一般是记脉冲数)才触发

定时器不需要检测引脚,直接计数

先说中断的代码


#include

#include

 

#define SDT P0//静态数码管定义

 

unsigned char temp;

 

unsigned char code SDT_map[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};//静态数码管字模

 

void delay10ms(unsigned int c)

{

unsigned int i,j;

for(;c>0;c--)

for(i=38;i>0;i--)

for(j=130;j>0;j--);

}

 

void interCongf()

{

//设置中断0

IT0=1;//IT=0表示低电平触发   IT=1表示负跳变沿触发

EX0=1;//EX为外部中断的允许位

PX0=0;//PX=0表示低优先级   PX=1表示高优先级

//设置中断1

IT1=1;

EX1=1;

PX1=1;//中断1的优先级比中断0高

 

EA=1;//总中断允许位

}

 

void main()

{

unsigned char ininum=0;

interCongf();

SDT=0x00;

while(1){}

}

 

void inter0() interrupt 0 //外部中断0

{

EX0=0;

for(temp=0;temp<10;temp++) //中断内部无法定义函数

{

SDT=SDT_map[temp];

delay10ms(10);

}

EX0=1;  //在开始和结尾关开中断,防止中断运行过程中误触

}

 

//void timer0() interrupt 1  {}  //定时器中断0   

 

void inter1() interrupt 2 //外部中断1

{

EX1=0;

SDT=0xff;

delay10ms(30);

EX1=1;

}

  

//void timer1() interrupt 3  {}  //定时器中断1

 

//void serialport() interrupt 4  {} //串行口中断



其中,SDT为共阳极静态数码管,P3.2(INT0)与P3.3(INT1)两个引脚分别接两个共阴的开关K1与K2


这个程序的功能就是无按键时,数码管全亮(0x00),


当按下K1时,数码管从一走到九


当按下K2时,数码管熄灭600ms,如果在INT0的执行过程中按K2,INT0会被中断(其实是挂起),立刻执行INT1,完成INT1后再返回INT0




然后说说计数器


#include

#include

 

#define SDT P0//静态数码管定义

sbit pulse=P1^0;

 

unsigned char temp=0;

 

unsigned char code SDT_map[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};//静态数码管字模

 

void delay10ms(unsigned int c)

{

unsigned int i,j;

for(;c>0;c--)

for(i=38;i>0;i--)

for(j=130;j>0;j--);

}

 

void timeConfg()

{

TMOD=0x05; //选用计数模式和 选用模式1

TH0=0xD8;

TL0=0xF6; //计数10000次

EA=1;

ET0=1;

TR0=1;

}

 

void main()

{

SDT=0xff;

timeConfg();

while(1)

{

pulse=0;

_nop_();

_nop_();

_nop_();

_nop_();

pulse=1;

_nop_();

_nop_();

_nop_();

_nop_();

}

}

 

//void inter0() interrupt 0   {} //外部中断0

 

void timer0() interrupt 1    //定时器中断0

{

TH0=0xD8;//如果不更新TH0与TL0的值,第二次计数将从0~65535+1

TL0=0xF6;

SDT=SDT_map[(temp++)%10];

}

 

//void inter1() interrupt 2   {} //外部中断1

  

//void timer1() interrupt 3  {}  //定时器中断1

 

//void serialport() interrupt 4  {} //串行口中断



定时器


#include

#include

 

#define SDT P0//静态数码管定义

 

unsigned char temp=0, status=0;

 

unsigned char code SDT_map[10]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90};//静态数码管字模

 

void timeConfg()

{

TMOD=0x01; //选用定时器模式和 选用模式1

TH0=0xd8;

TL0=0xf0; //定时  计数10000次

EA=1;

ET0=1;

TR0=1;

}

 

void main()

{

SDT=SDT_map[temp];

timeConfg();

while(1)

{

if(status==100)

{

temp++;

status=0;

SDT=SDT_map[temp%10];

}

}

}

 

//void inter0() interrupt 0   {} //外部中断0

 

void timer0() interrupt 1    //定时器中断0

{

TH0=0xd8;//如果不更新TH0与TL0的值,第二次计数将从0~65535+1

TL0=0xf0;

status++;

}

 

//void inter1() interrupt 2   {} //外部中断1

  

//void timer1() interrupt 3   {}  //定时器中断1

 

//void serialport() interrupt 4  {} //串行口中断

 


其实定时器和计数器很相似,只用在TMOD里修改就行




总结:


其实中断,计数器,定时器很相似


共用的寄存器:定时计数器控制寄存器TCON, 中断优先寄存器IP 和 中断允许寄存器IE


定时计数器特有的寄存器:工作方式寄存器TMOD


附一些有关这些寄存器的资料:




关键字:51单片机  中断  定时计数器

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/2018/ic-news071240280.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:51单片机中用中断方式实现串口数据发送与接收
下一篇:51单片机中断设置

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

单片机A/D采样的原理

在A/D转换器中,因为输入的模拟信号在时间上式连续的,而输出的数字信号代码是离散的。所以A/D转换器在进行转换时,必须在一系列选定的瞬间(时间轴上的一些规定点上)对输入的模拟信号采样保持,然后再把这些采样值转换为数字量。因此,一般的A/D转换过程是通过采样保持、量化和编码这三个步骤完成的,即首先对输入的模拟电压采样保持,采样结束后进入保持时间,在这段时间内将采样的电压量转化为数字量,并按一定的编码形式给出转换结果,然后开始下一次采样。下图给出模拟量到数字量转换过程图:1、采样定理 可以证明,为了正确无误的用5.2.2图中所示的采样信号Vs表示模拟信号V1,必须满足: 因此,A/D转换器工作时采样频率必须高于上式所
发表于 2018-12-01
单片机A/D采样的原理

单片机C语言函数之中断函数

INT0请求标志位)和IE1由硬件自动清零;在电平触发方式下,不能自动清楚IE0和IE1。所以在中断返回前必须撤出INT0和INT1引脚的低电平,否则就会出现一次中断被CPU多次响应。     (3)串口中断中,CPU响应中断后,TI(串行口发送中断请求标志位)和RI(接收中断请求标志位)必须由软件清零。     (4)单片机复位后,TCON,SCON给位清零。C51语言允许用户自己写中断服务子程序(中断函数)首先来了解程序的格式:void 函数名() interrupt m [using n] {}关键字 interrupt m [using n] 表示这是一个
发表于 2018-12-01

STM32单片机串口的深思

其实学单片机使用的时候,往往大家都觉得简单,很快就过了,但其实有一些东西是值得深思的,我以前在写程序的时候往往都是发送数据,那么调用重写的printf()函数就可以了,但这次的项目中用到了NRF双全工通讯,这就需要串口的收发,这回就发生了写问题,具体的流水账就不说了。简单说就是串口收可比发讲究多了。void USART1_IRQHandler(void)                //串口1中断服务程序{u8 i;if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)//如果寄存器中有
发表于 2018-11-30

STM8L15x系列单片机独立看门狗配置

时钟采用LSI时钟,频率为38000Hz;为了使看门狗周期尽量大,将分频系数设置为256分频;因此在256分频情况下,看门狗超时时间最长,时间为1.7s左右:(254+1)*256/38000 = 1.717sTwdg = (C + 1) * PreDiv / f;其中:    C为计数值,取值范围为0~254;    PreDiv为分频系数,取固定值256;    f为LSI时钟频率,固定为38000;
发表于 2018-11-30

单片机/ARM死机的常见原因及解决方案

前几天在写ARM时经常死机,莫名其妙,在这搜集了一些比较好的解答和方案,给大家参考。可能原因:一 振荡器停止振荡又可以分为电源电压不稳,或者强干扰引起的振荡器停振。二 PC指针跑飞电源电压不稳或强干扰引起PC跑飞,如果看门狗不好,也会引起死机。三 设计上对长引出线的IO没有保护,静电打在IO口上引起单片机死锁,破坏了硬件逻辑功能,导致死机。四. 复位收到干扰,引起反复复位,在反复复位当中有可能会导致死机。五.电源电压 的地 不稳  ,造成电源电压 瞬间负电压 导致单片机故障 程序不发运行综上所述:设计电路时,应该注意:1.电源稳定2.IO保护3.振荡器PCB布线要注意4.复位电路设计和PCB布线5.电源,信号线干扰路径
发表于 2018-11-30
单片机/ARM死机的常见原因及解决方案

单片机看门狗的概念,原理,运用

的运行过程中,我们要在定时时间到之前对定时器进行复位如果出现死循环,或者说PC指针不能回来。那么定时时间到后就会使单片机复位。常用的WDT芯片如MAX813 ,5045, IMP 813等,价格4~10元不等.软件看门狗技术的原理和这差不多,只不过是用软件的方法实现,我们还是以51系列来讲,我们知道在51单片机中有两个定时器,我们就可以用这两个定时器来对主程序的运行进行监控。我们可以对T0设定一定的定时时间,当产生定时中断的时候对一个变量进行赋值,而这个变量在主程序运行的开始已经有了一个初值,在这里我们要设定的定时值要小于主程序的运行时间,这样在主程序的尾部对变量的值进行判断,如果值发生了预期的变化,就说明T0中断正常,如果没有发生变化则使
发表于 2018-11-29

小广播

何立民专栏

单片机及嵌入式宝典

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

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2018 EEWORLD.com.cn, Inc. All rights reserved
pt type="text/javascript" src="//v3.jiathis.com/code/jia.js?uid=2113614" charset="utf-8">