#include<reg52.h>
#define uchar unsigned char
#define uint unsigned int
sbit key1=P3^4;
sbit key2=P3^5;
sbit key3=P3^6;
sbit key4=P3^7;
sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delayms(uint);
uchar numt0,num;
void display(uchar numdis)
{
uchar shi,ge;
shi=numdis/10;
ge=numdis%10;
dula=1;
P0=table[shi];
dula=0;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
delayms(5);
dula=1;
P0=table[ge];
dula=0;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
delayms(5);
}
void delayms(uint xms)
{
uint i,j;
for(i=xms;i>0;i--)
for(j=110;j>0;j--);
}
void init()
{
TMOD=0x01;
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
EA=1;
ET0=1;
}
void keyscan()
{
if(key1==0)
{
delayms(10);
if(key1==0)
{
num++;
if(num==60)
num=0;
while(!key1);
}
}
if(key2==0)
{
delayms(10);
if(key2==0)
{
if(num==0)
num=60;
num--;
while(!key2);
}
}
if(key3==0)
{
delayms(10);
if(key3==0)
{
num=0;
while(!key3);
}
}
if(key4==0)
{
delayms(10);
if(key4==0)
{
while(!key4);
TR0=~TR0;
}
}
}
void main()
{
init();
while(1)
{
keyscan();
display(num);
}
}
void T0_
time() interrupt 1
{
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
numt0++;
if(numt0==1)
{
numt0=0;
num++;
if(num==60)
num=0;
}
}
你的程序中,中断源是定时器,当定时器计数溢出时会产生一个溢出脉冲(中断请求信号),该脉冲会将相应的中断标志位置位,CPU检测到标志位被置位后,将暂停当前正在执行的程序,转而去执行中断服务函数;当中断服务函数执行完成,CPU将回到暂停的程序开始继续执行。中断涉及到压堆栈和出堆栈。
现在回答你的问题:我不知道CPU从什么地方进入中断,因为我不知道定时器什么时候溢出,定时器溢出时CPU正在执行哪条语句。有一点我是知道的,一定是在你的main()函数中由while(1)构成的死循环中进入中断服务函数的。
你需要回去看中断系统一章的内容,并且你一定要知道为什么中断服务程序最后一条汇编指令是RETI。
{
TMOD=0x01;//定时器0方式一,16位重装初值。
EA=1;
ET0=1;
TR0=1;
}
}
void Timer0_isr(void) interrupt 1
{
TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
numt0++;
if(numt0==1)
{
numt0=0;
num++;
if(num==60)
num=0;
}
}
由于 TH0=(65536-45872)/256;
TL0=(65536-45872)%256;
当TH0,TL0 计数溢出时(即重装初值),这时产生中断,处理后面的程序;你这样书写程序好乱!不行的
一周热门 更多>