当前位置:首页 » 编程语言 » c语言定时器中断程序
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言定时器中断程序

发布时间: 2022-12-20 09:53:16

1. 51单片机c语言对流水灯编程,用定时中断做

#include<reg52.h>
#defineucharunsignedchar
ucharm=0,i=0;
voidmain()
{
TMOD|=0x01;//定时器0工作方式为1
TH0=(65536-50000)/256;//装初值
TL0=(65536-50000)%256;
EA=1;//开总中断
ET0=1;//开定时器中断
TR0=1;//开启定时器

while(1);//等待中断

}
voidtimer0()interrupt1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
m++;
if(m==5)//12M晶振定时5*50MS=250MS
{
m=0;
P1=~(0X01<<i);//P1接8个LED
if(++i==8)
i=0;
}
}

[补充]

延时函数是一种粗略计算延时时间的函数
是通过让单片机执行空指令,达到等待延时的目的。
经常被应用在对延时时间要求不太严格的场合。
而定时器中断,则是通过对晶振时钟进行计数
由于晶振的频率一般是很稳定的,所以晶振的脉冲频率基本稳定
从而通过对脉冲进行计数即可得到准确的延时目的。
中断延时函数和定时器中断延时没有明确的对应关系。
主要是根据你的应用场合来确定使用哪种函数。

2. 单片机C语言定时中断LED灯程序求修改

#include<reg52.h>
sbit P00=P0^0;
sbit key=P1^0;
unsigned int i=0;
void main(void)
{
TMOD=0x10;//设定定时器的工作模式为定时器1方式1
TH1=15536/256;//向定时器装入初值高八位
TL1=15536%256;//向定时器装入初值低八位
EA=1;//开总开关
ET1=1;//开分开关
TR1=1;//启动定时器
while(1)
{
if(key==0)TR1=0;

else TR1=1;

}
}
void t1(void) interrupt 3//定时器0服务函数
{
TH1=15536/256;//向定时器装入初值高八位
TL1=15536%256;//向定时器装入初值低八位

if(++i==30)//延时1.5S
{
i=0;
P00=~P00;//闪烁
}
}

3. 定时器1中断刷新,从999999~0倒计时,求C语言程序

这个和代码顺序有关系:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
while
(1)
{
if
(flag1s
==
1)
//判断1秒定时标志
{
flag1s
=
0;
//1秒定时标志清零
sec--;
//秒计数自减1【这里是先减一,后面再送显示】
//将sec按十进制位从低到高依次提取到buf数组中
buf[0]
=
sec%10;
buf[1]
=
sec/10%10;
buf[2]
=
sec/100%10;
buf[3]
=
sec/1000%10;
buf[4]
=
sec/10000%10;
buf[5]
=
sec/100000%10;
//从最高为开始,遇到0不显示,遇到非0退出循环
}
}
如果初值要改为999999,代码可以改成如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
while
(1)
{
if
(flag1s
==
1)
//判断1秒定时标志
{
flag1s
=
0;
//1秒定时标志清零
//
sec--;
//秒计数自减1【屏蔽】
//将sec按十进制位从低到高依次提取到buf数组中
buf[0]
=
sec%10;
buf[1]
=
sec/10%10;
buf[2]
=
sec/100%10;
buf[3]
=
sec/1000%10;
buf[4]
=
sec/10000%10;
buf[5]
=
sec/100000%10;
sec--;
//秒计数自减1【这里是先送显示,后面再减一】
//从最高为开始,遇到0不显示,遇到非0退出循环
}
}

4. 单片机定时器中断问题(c语言)

我把你现在给出的这个程序的分析和调试了一下,并且我在里面加入了一些代码使能能够通过串口输出来观察数据,,一开始是进入到xian1()中的,,就是你的显示为0的这个函数中的,然后当nDataToDisplay<200这个条件不满足的时候,程序就开始进入xian()中,也就是你的显示为9999的函数中,,,,然后又循环到一开始的状态。
就函数已经在你指定的地方调用了,,,,如果有问题,,就要检查你的显示函数和相应硬件连接了。

5. C语言的中断函数做定时器

使用c++编译器,就要求中断函数的形参用...填充。非c++编译器就不用形参。这个不用深追究为什么,只要这样用就可以了。

6. 51单片机定时中断C语言的写法步骤,可追加分数

程序说明:51单片机定时器0工作于方式一,定时50ms中断一次
晶振为12M
#include

void
main
{
TOMD
=
0X01;
//配置定时器0工作于方式一
TH1
=
(65536-50000)/256;
//高八位装入初值
TL1
=
(65536-50000)%256;
//低八位装入初值
ET0
=
1;
//开定时器0中断
EA
=
1;
//开总中断
TR0
=
1;
//启动定时器0
while(1)
{

}
}
void
Timer0_int()
interrupt
1
{
//重新装初值
TH1
=
(65536-50000)/256;
//高八位装入初值
TL1
=
(65536-50000)%256;
//低八位装入初值
}
/***************************************************************************************************************/
上面是比较好理解的。如果实在要求简洁的话,看下面的,跟上面功能一样
#include

void
main
{
TOMD
=
0X01;
//配置定时器0工作于方式一
TH1
=
0x3c;
//高八位装入初值
TL1
=
0xb0;
//低八位装入初值
IE
=
0x82;//开总中断并开定时器0中断
TR0
=
1;
//启动定时器0
while(1)
{

}
}
void
Timer0_int()
interrupt
1
{
//重新装初值
TH1
=
0x3c;
//高八位装入初值
TL1
=
0xb0;
//低八位装入初值}

7. 单片机C语言编程如何实现定时器中断1s编程

以下是一个实时时钟的程序,里面包含有1S定时器,你也可以使用延时程序,但是不精确
/*备注:按键一为功能键,按一下调年,按两下调月,按三下调日,按四下调时,按五下调分*/
/* 按六下退出,或者在任何时候按键四退出设定状态。在设定状态键二加一,键三减一*/
/* 键四退出,正常状态键二显示年,键三显示月日,键四显示星期和秒*/
/* 星期根据日期计算得出,其已全部调试通过,为了时间精确,要调一个误差值*/

#include<reg2051.h>
#include<stdio.h>
#include<absacc.h>
#include<intrins.h>

#define uint unsigned int
#define uchar unsigned char

uchar code led_xs[12]={0x03,0x9f,0x25,0x0d,0x99,0x49,0x41,0x1f,0x01,0x09,0xff,0xfd};
uchar data led_data[4];
volatile uchar data a; //定义按键一志标
volatile uchar data month=4; //定义月并赋初值
volatile uchar data date=29; //定义日并赋初值
volatile uchar data week; //定义星期并赋初值
volatile uchar data hour; //定义时
volatile uchar data min; //定义分
volatile uchar data sec=0; //定义秒
volatile uint data zn=0; //定义中间存储变量
volatile uint data year=2007; //定义年并赋初值

sbit md=P3^7; //定义秒点
sbit k1=P1^0; //定义按键一
sbit k2=P1^1; //定义按键二
sbit k3=P1^2; //定义按键三
sbit k4=P1^3; //定义按键四
sbit hs=P1^4; //定义显示片选信号一
sbit hg=P1^5; //定义显示片选信号二
sbit ms=P1^6; //定义显示片选信号三
sbit mg=P1^7; //定义显示片选信号四
bit sans; //定义闪烁标志
bit b; //定义按键二标志
bit c; //定义按键三标志
bit w; //定义按键四标志
bit x; //定义24小时到标志
bit y; //定义日期加一标志

keyscan(); //申明键盘扫描函数
void display(); //申明显示函数
void chushihua(void); //申明初始化函数
void delay_10ms(void); //申明10ms延时函数
dateadd(); //申明日期加函数
datesub(); //申明日期减函数
weekjs(); //星期计算函数

void main(void)
{
weekjs(); //计算初值星期几
x=y=0; //日期加初始化
chushihua(); //调初始化函数,初始化定时器,中断
do{
keyscan(); //键盘扫描
display(); //调用显示函数
if((!y)==x)dateadd(); //判断是否有24小时,有就调用日期加函数
}
while(1); //先调用显示键盘
}

void chushihua(void) //初始化函数
{
TMOD=0x02; //定时器0以方式2工作,自动重装初值
IE=0x82; //开总中断和TO中断
TH0=0x06; //T0高位置初值
TL0=0x06; //T0低位置初值
TR0=1; //启动TO
}

timer0 () interrupt 1 //T0中断函数
{
if(zn<4000){zn++;if(zn==2000)sans=!sans;}
else {zn=0;sec++;sans=!sans;
if(sec==60){sec=0;min++;
if(min==60){min=0;hour++;
if(hour==24){hour=0;x=!x;}
}
}
}
}

void display()
{
uchar k;
uint d;
uchar e;
SCON=0x00;
P1=0x0f;
if((a!=0)&&sans){
led_data[3]=10;
led_data[2]=10;
led_data[1]=10;
led_data[0]=10;
}
else {
switch(a){
case 0 :led_data[3]=hour/10;
led_data[2]=hour%10;
led_data[1]=min/10;
led_data[0]=min%10;
break;
case 1 :led_data[3]=year/1000;
d=year%1000;
led_data[2]=d/100;
e=d%100;
led_data[1]=e/10;
led_data[0]=e%10;
break;
case 2 :led_data[3]=month/10;
led_data[2]=month%10;
led_data[1]=10;
led_data[0]=10;
break;
case 3 :led_data[3]=10;
led_data[2]=10;
led_data[1]=date/10;
if(led_data[1]==0)led_data[1]=10;
led_data[0]=date%10;
break;
case 4 : led_data[3]=hour/10;
led_data[2]=hour%10;
led_data[1]=10;
led_data[0]=10;
md=0;
break;
case 5 : led_data[3]=10;
led_data[2]=10;
led_data[1]=min/10;
led_data[0]=min%10;
md=0;
break;
default: break;
}
}
if(b){
led_data[3]=year/1000;
d=year%1000;
led_data[2]=d/100;
e=d%100;
led_data[1]=e/10;
led_data[0]=e%10;
}
else if(c){
led_data[3]=month/10;
led_data[2]=month%10;
led_data[1]=date/10;
if(led_data[1]==0)led_data[1]=10;
led_data[0]=date%10;
}
else if(w){
led_data[3]=week;
led_data[2]=11;
led_data[1]=sec/10;
led_data[0]=sec%10;
}
if((led_data[3]==0)&&(!w))led_data[3]=10;
k=led_data[3];
SBUF=led_xs[k];
while(!TI){}
TI=0;
hs=1;
for(k=0;k<255;k++){_nop_();_nop_();_nop_();}
hs=0;

k=led_data[2];
SBUF=led_xs[k];
while(!TI){}
TI=0;
hg=1;
for(k=0;k<255;k++){_nop_();_nop_();_nop_();}
hg=0;

k=led_data[1];
SBUF=led_xs[k];
while(!TI){}
TI=0;
ms=1;
for(k=0;k<255;k++){_nop_();_nop_();_nop_();}
ms=0;

k=led_data[0];
SBUF=led_xs[k];
while(!TI){}
TI=0;
mg=1;
for(k=0;k<255;k++){_nop_();_nop_();_nop_();}
mg=0;

if(!(a||b||c||w)){
SBUF=0xff;
while(!TI){}
TI=0;
ms=1;
mg=1;
md=sans;
for(k=0;k<255;k++){_nop_();_nop_();}
P1=0x0f;
md=1;
}
}

keyscan()
{
uchar key_value,reread_key;
P1=0x0f;
key_value=P1&0x0f;
if(key_value!=0x0f){
delay_10ms();
reread_key=P1&0x0f;
if(key_value==reread_key){
switch(key_value){
case 0x0e : if(!(b||c||w)){a++;if(a==6)a=0;}
else b=c=w=0;
break;
case 0x0d : switch(a){
case 0 : b=!b;c=w=0;break;
case 1 : year++;break;
case 2 : if(month<12)month++;else month=1;break;
case 3 : dateadd();break;
case 4 : hour++;if(hour==24)hour=0;break;
case 5 : min++;if(min==60)min=0;break;
default: break;
}
break;
case 0x0b : switch(a){
case 0 : c=!c;b=w=0;break;
case 1 : year--;break;
case 2 : month--;if(month==0)month=12;break;
case 3 : datesub();break;
case 4 : hour--;if(hour==0xff)hour=23;break;
case 5 : min--;if(min==0xff)min=59;break;
default: break;
}
break;
case 0x07 : if(a==0){w=!w;b=c=0;}
else{a=0;b=c=w=0;}
break;
default : break;
}
P1=0x0f;
reread_key=P1&0x0f;
while(key_value==reread_key){
reread_key=P1&0x0f;
display();
}
}
}
}

void delay_10ms(void)
{
uchar o,p,q;
for(o=5;o>0;o--)
for(p=4;p>0;p--)
for(q=248;q>0;q--);
}

datesub()
{
switch(month){
case 1 : date--;if(date==0) date=31;break;
case 2 : date--;if(((year%4==0)&&(date==0))==1)date=29;
else if(date==0) date=28;break;
case 3 : date--;if(date==0) date=31;break;
case 4 : date--;if(date==0) date=30;break;
case 5 : date--;if(date==0) date=31;break;
case 6 : date--;if(date==0) date=30;break;
case 7 : date--;if(date==0) date=31;break;
case 8 : date--;if(date==0) date=31;break;
case 9 : date--;if(date==0) date=30;break;
case 10: date--;if(date==0) date=31;break;
case 11: date--;if(date==0) date=30;break;
case 12: date--;if(date==0) date=31;break;
default: break;
}
weekjs();
}

weekjs()
{
uchar c,m,wk,pd,yz;
uint y,p;
if(month==1){m=13;y=year-1;}
else if(month==2){m=14;y=year-1;}
else {y=year;m=month;}
c=y/100;
yz=y%100;
wk=2*c+1;
p=26*(m+1);
pd=p/10;
pd=pd+yz+(yz/4)+(c/4)+date;
if(pd>wk)week=(pd-wk)%7;
else if(pd<wk){week=(7-((wk-pd)%7));if(week==7)week=0;}
else week=0;
}

dateadd()
{
switch(month){
case 1 : date++;if(date==32){date=1;if(a!=3)month++;}break;
case 2 : date++;if(((year%4==0)&&(date==30))==1){date=1;if(a!=3)month++;}
else if(date==29){date=1;if(a!=3)month++;}break;
case 3 : date++;if(date==32){date=1;if(a!=3)month++;}break;
case 4 : date++;if(date==31){date=1;if(a!=3)month++;}break;
case 5 : date++;if(date==32){date=1;if(a!=3)month++;}break;
case 6 : date++;if(date==31){date=1;if(a!=3)month++;}break;
case 7 : date++;if(date==32){date=1;if(a!=3)month++;}break;
case 8 : date++;if(date==32){date=1;if(a!=3)month++;}break;
case 9 : date++;if(date==31){date=1;if(a!=3)month++;}break;
case 10: date++;if(date==32){date=1;if(a!=3)month++;}break;
case 11: date++;if(date==31){date=1;if(a!=3)month++;}break;
case 12: date++;if(date==32){date=1;if(a!=3)month++;}break;
default: break;
}
if(month==13){month=1;year++;}
y=x;
weekjs();
}

8. 求教一个简单的C语言定时器中断程序

每中断一次,程序就会执行一次中断程序,也就是会执行“void t0_rpt() interrupt 1”这个程序

9. c语言怎么编写单片机的中断

标准c语言没有中断调用机制,但是不同编译器都有相应的中断处理方式,可以使用户实现中断功能。
解决方案:
1、采取轮询的方式解决,就是每10毫秒检查一下是否有键盘请求,总的来说,这样基本上可以解决问题,而且简单易行,但每10毫秒都要检查,系统消耗太大。
2、采取中断的方式:
(1)用高级语言调用中断来处理问题。中断是cpu响应一个中断外围设备8259A的一个过程,当键盘敲击,cpu保存断点暂停执行并且跳到相应的中断处理程序继续执行,结束后根据断点再跳回来。通过这种方式可以轻松+愉快地解决这个问题。但是需要用到高级语言调用汇编,根据编译器的不同而有所差别。
(2)自己模拟中断。可以另外建立一个线程专门响应键盘的敲击,如果有敲击则打断主线程。这样做实现起来很复杂,而且涉及到不少复杂的关键技术,比如信号量之类的东西。
3、强大的vc
vc采取了消息映射的机制来处理外部设备的请求,比如时钟中断、键盘中断等等。通过此可以灰常灰常容易的处理外部中断。