⑴ 单片机定时中断
跟你理清一下思路,你的问题就解决了。首先,你的程序很简单,就是让发光二极管1秒亮1秒灭。因此,你前提是要定时1秒,但51单片机无法定时1秒,因此,你的程序就要定时50毫秒,每到了50毫秒,你就让num自加1,当num加到20时,换句话说,已经定时50毫秒20次了,那就是1秒咯,所以此有led1=~led1; //让发光管状态取反,达到程序目的。另外,定时50毫秒你要给TH0和TL0赋给初值,因此 TH0=(65536-45872)/256; //重新装载初值TL0=(65536-45872)%256;才会有这两句,但定时50毫秒后,你的初值也会随之消失,因此才会在void T0_time()这个函数中重新赋初值。的确像你所说的初值是装满了开始执行中断,其实从你TMOD=0x01; //设置定时器0位工作模式1(M1,M0位0,1)这句已经开始定时了,而赋初值是为了准确的定时50毫秒罢了。明白了没有?
(其实你可以这样理解,定时计数器就好比一个空的瓶子,当你给TMOD=0x01时,水就开始一滴一滴的往瓶子你滴,当瓶子满了的时候,中断就发生了。假如从一个空的瓶子滴到满的瓶子定时是80毫秒的话,可你只需要定时50毫秒就够了,所以就要一开始往瓶子里倒水,使滴水的起点不是空瓶子,这就是赋初值的作用。当瓶子满了后,瓶子就会自动清空,重新从零开始。而第二次你再想定时50毫秒,你就必须从新再往瓶子里倒水,这就是第二次赋初值的作用)
⑵ 请问单片机定时器中断是怎么样的过程啊
1:如果是中断只有一次,那么没有下一次起始。
2:如果是多次中断,那么每一次结束后定时器数值将会被重置。
一:循环定时中断——定时的时间是循环到定时程序的时间。
二:条件定时中断——定时的时间是条件语句结束的时间(如果中断程序里面不改变条件)。
也就是说,在定时一段时间后进入中断,定时的开始与中断无关。一楼说的应该是定时器中断,及在中断程序里面会改定时数值。楼主所讲的应该是中断前加一个延时。
⑶ 什么是单片机的中断
不同的计算机其硬件结构和软件指令是不完全相同的,因此,中断系统也是不相同的。
计算机的中断系统能够加强CPU对多任务事件的处理能力。中断机制是现代计算机系统中的基础设施之一,它在系统中起着通信网络作用,以协调系统对各种外部事件的响应和处理。中断是实现多道程序设计的必要条件。 中断是CPU对系统发生的某个事件作出的一种反应。
引起中断的事件称为中断源。中断源向CPU提出处理的请求称为中断请求。发生中断时被打断程序的暂停点称为断点。
CPU暂停现行程序而转为响应中断请求的过程称为中断响应。处理中断源的程序称为中断处理程序。
CPU执行有关的中断处理程序称为中断处理。而返回断点的过程称为中断返回。中断的实现实行软件和硬件综合完成,硬件部分叫做硬件装置,软件部分称为软件处理程序。
响应处理
大多数中断系统都具有如下几方面的操作,这些操作是按照中断的执行先后次序排列的。
1、 接收中断请求。
2、 查看本级中断屏蔽位,若该位为1则本级中断源参加优先权排队。
3、 中断优先权选择。
4、 处理机执行完一条指令后或者这条指令已无法执行完,则立即中止现行程序。接着,中断部件根据中断级去指定相应的主存单元,并把被中断的指令地址和处理机当前的主要状态信息存放在此单元中。
5、 中断部件根据中断级又指定另外的主存单元,从这些单元中取出处理机新的状态信息和该级中断控制程序的起始地址。
6、 执行中断控制程序和相应的中断服务程序。
7、 执行完中断服务程序后,利用专用指令使处理机返回被中断的程序或转向其他程序。
冲突
在一些罕见的情况下,两个ISA设备可以共享相同的 IRQ,只要它们不同时使用即可。为了解决这个问题,后来的PCI 总线允许 IRQ 共享。PCI Express没有物理中断线,并使用消息信号中断(MSI) 到操作系统(如果可用)。
在早期的 IBM 兼容个人计算机中,中断曾经是一种常见的硬件错误,当两个设备尝试使用相同的中断请求(或 中断)向可编程中断控制器(PIC)发出中断信号时会收到该错误。
PIC 期望每条线路仅来自一个设备的中断请求,因此沿同一条线路发送中断信号的多个设备通常会导致 中断 冲突,从而导致计算机死机。
例如,如果在系统中添加调制解调器扩展卡并分配给中断4,传统上分配给串行端口1,则可能会导致中断冲突。最初,中断 7 是使用声卡的常见选择,但后来发现 中断 7 会干扰打印机端口(LPT1)时使用了中断5。该串行端口经常禁用可以用于其他设备的中断线。
中断 2/9 是 MPU-401 MIDI 端口的传统中断线,但这与ACPI系统控制中断(SCI 在 Intel 芯片组上硬连线到 中断9)冲突;
这意味着 ISAMPU-401带有硬连线中断2/9 的卡和带有硬编码 中断 2/9 的 MPU-401 设备驱动程序不能在启用 ACPI 的系统上以中断驱动模式使用。
以上内容参考网络-中断
⑷ 51单片机定时器中断原理
原理很简单,说白了就是用一个计数器对内部时钟计数,计满溢出时触发定时器中断,此时,程序会中断执行当前代码跳转到一个固定地址(定时器中断服务程序入口)去执行中断服务程序,执行完毕再回到被中断的代码地址继续执行。
⑸ 单片机定时器中断的问题
void
T1_INT()interrupt
3
{
TH1=(65536-1000)/256;
TL1=(65536-1000)%256;
BEEP=-BEEP;
//根据高温还是低温警报设定不同延时间隔
if(L_LED==0)//L_LED一定是低温/高温显示,即L_LED==0是低温;==1是高温
{//如果是低温时,看看t到没到150,如果没到直接返回
if(++t!=150)
return;
}
else
{//L_LED==1,说明是高温,看看t到没到60,如果没到直接返回
if(++t!=60)
return;
}
\\低温时(L_LED==0),t==150说明是延时到了;或者高温时(L_LED==1),t==60说明延时到了。
t=0;//t清零
DelayMS(20);//延时
}
⑹ 单片机定时器中断是啥意思,有谁知
单片机定时器中断就是定时器计时溢出时,会申请中断,如果中断标志被置位了的话,就会进入中断服务程序。
⑺ 51单片机中的定时器中断是怎么用的
代码如下:
//实现led灯一秒亮灭闪烁
void main()
{
TMOD=0x01;//设置定时器0为工作方式1(M1 M0为01)
TH0=(65536-45872)/256;//装初值11.0582晶振定时50ms数为45872
TL0=(65536-45872)%256;
EA=1;//开总中断
ET0=1;//开定时器0中断
TR0=1;//启动定时器0
while(1);//程序停止在这里等待中断发生
}
void T0_time() interrupt 1
{
TMOD=0x01;//重装初值
TH0=(65536-45872)/256;
num++;//num每加一次判断一次是否到20次
if(num==20)//如果到了20次,说明1秒时间到
{
num=0;//num清0重新计数
led=~led1;
}
}
(7)单片机计时中断扩展阅读
定时器有两种工作模式,分别为计数模式和定时模式。对Px,y的输入脉冲进行计数为计数模式。定时模式,则是对MCU的主时钟经过12分频后计数。因为主时钟是相对稳定的,所以可以通过计数值推算出计数所经过的时间。
51单片机计数器的脉冲输入脚。主要的脉冲输入脚有Px,y, 也指对应T0的P3.4和对应T1的P3.5,主要用来检测片外来的脉冲。而引脚18和19则对应着晶振的输入脉冲,脉冲的频率和周期为
F = f/12 = 11.0592M/12 = 0.9216MHZ T = 1/F = 1.085us
51计数器的计数值存放于特殊功能寄存器中。T0(TL0-0x8A, TH0-0x8C),T1(TL1-0x8B, TH1-0x8D)
定时器常用作定时时钟,以实现定时检测,定时响应、定时控制,并且可以产生ms宽的脉冲信号,驱动步进电机。定时和计数的最终功能都是通过计数实现,若计数的事件源是周期固定的脉冲则可实现定时功能,否则只能实现计数功能。因此可以将定时和计数功能全由一个部件实现。
⑻ 单片机定时器中断
#include <pic.h> //调用头文件,可以去PICC软件下去查找PIC16F87XA单片机的头文件
__CONFIG(XT&WDTEN&LVPDIS); //定义配置字,晶振类型:XT,启动开门狗,禁止低电压编程
#define HC138_A RE2 //定义U6、U7、U8的A为RE2端口
#define HC138_B RE1 //定义U6、U7、U8的B为RE1端口
#define HC138_C RE0 //定义U6、U7、U8的C为RE0端口
#define U6_E RA2 //定义U6_E为RA2端口,U6E=1时,U6使能否则失能
#define U7_E RA3 //定义U7_E为RA3端口,U7E=1时,U7使能否则失能
#define U8_E RA1 //定义U8_E为RA1端口,U8E=1时,U8使能否则失能
#define V1 RA5 //定义V1为RA5端口
unsigned int tmcon;
//---------------------------------------
//名称: 初始化函数
//日期:20101001
//-----------------------------------------
void init(void)
{
ADCON1=0X06; //所有IO均为数字口,模拟量输入禁止
OPTION=0x80; //关闭RB口电平变化功能
TRISA=0B11010001; //RA1,RA2,RA3,RA5置为输出,其他未用设置为输入
TRISB=0B11111111; //其他未用设置为输入
TRISC=0B11111111; //其他未用设置为输入
TRISD=0B11110011; //未用设置为输入
TRISE=0B11111000; //RE0,RE1,RE2置为输出,其他未用设置为输入
RD2=0; //关闭蜂鸣器
RD3=0; //关闭继电器
RA1=0; //关掉数码管、发光二极管
RA2=0; //关掉LED点阵屏左8列
RA3=0; //关掉LED点阵屏右8列
RBIE=0; //RB口电平变化中断禁止
}
//---------------------------------------
//名称: T0初始化函数
//日期:20100501
//-----------------------------------------
void timer0init(void)
{
T0CS=0; //TMR0工作于定时器方式
PSA=1; //TMR0不分频
T0IF=0; //清除TMR0中断标志
T0IE=1; //TMR0中断允许
TMR0=0x13; //赋初值,以便TMR0每250US中断一次
GIE=1;
}
//---------------------------------------
//名称: T0中断函数(250US)
//日期:20101001
//-----------------------------------------
void interrupt ISR(void)
{
if(TMR0IF==1) //250us
{
TMR0=0x13;
T0IF=0;
if(++tmcon>3999) //计数4000次后,为1秒
{
tmcon=0;
V1=!V1;
}
}
}
//---------------------------------------
//名称: 主函数
//日期:20101001
//-----------------------------------------
void main(void)
{
init();
timer0init();
V1=0; //熄灭V1
HC138_A=0; //使74HC138的Y0端为0,其他高阻
HC138_B=0; //使74HC138的Y0端为0,其他高阻
HC138_C=0; //使74HC138的Y0端为0,其他高阻
U6_E=0; //U6关闭
U7_E=0; //U7关闭
U8_E=1; //U8打开
while(1)
{
asm("CLRWDT");
}
}//[email protected]
⑼ 单片机定时中断
在中断程序中不要调延时子程序,通常,中断程序尽量要短,尽快从中断程序中返回,所以,是不能延时的,而且看你的程序不需要中断延时的。如下图修改。