单片机在这个程序的哪里进入中断

2019-07-15 16:40发布

#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;
        }
       
}


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
5条回答
dengxc
1楼-- · 2019-07-15 17:44
你的问题本身就是个问题,从你提出的问题来看,你还没有理解CPU响应中断的原理。记住:当某个中断源提出中断请求(中断请求是一个信号)时,硬件将置位相应的标志位,如果预先开放了CPU对这个中断源的响应,当CPU检测到标志位被置位后,CPU将暂停当前正在执行的程序代码,转而执行中断服务程序的代码。
你的程序中,中断源是定时器,当定时器计数溢出时会产生一个溢出脉冲(中断请求信号),该脉冲会将相应的中断标志位置位,CPU检测到标志位被置位后,将暂停当前正在执行的程序,转而去执行中断服务函数;当中断服务函数执行完成,CPU将回到暂停的程序开始继续执行。中断涉及到压堆栈和出堆栈。
现在回答你的问题:我不知道CPU从什么地方进入中断,因为我不知道定时器什么时候溢出,定时器溢出时CPU正在执行哪条语句。有一点我是知道的,一定是在你的main()函数中由while(1)构成的死循环中进入中断服务函数的。
你需要回去看中断系统一章的内容,并且你一定要知道为什么中断服务程序最后一条汇编指令是RETI。
小代码
2楼-- · 2019-07-15 20:54
void Timer0(void)
{
        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 计数溢出时(即重装初值),这时产生中断,处理后面的程序;你这样书写程序好乱!不行的
小代码
3楼-- · 2019-07-16 01:01
 精彩回答 2  元偷偷看……
andy_wsj
4楼-- · 2019-07-16 03:18
找到工程中的中断向量表,中断函数应该在那里被设置,不在这个文件中
何时的丁丁
5楼-- · 2019-07-16 09:18
每次50ms就会进入一次中断,如果晶振是11.0592的话每一条语句是1us你看看是那条语句进入的

一周热门 更多>