求一个51单片机定时中断中断程序 ~

 上传我的文档
 下载
 收藏
粉丝量:133
该文档贡献者很忙,什么也没留下。
 下载此文档
51单片机定时器中断程序(C语言)
下载积分:300
内容提示:51单片机定时器中断程序(C语言)
文档格式:PDF|
浏览次数:3106|
上传日期: 03:40:36|
文档星级:
全文阅读已结束,如果下载本文需要使用
 300 积分
下载此文档
该用户还上传了这些文档
51单片机定时器中断程序(C语言)
关注微信公众号2被浏览500分享邀请回答0添加评论分享收藏感谢收起写回答51单片机定时、中断练习:用延时程序做闪烁灯
> 51单片机定时、中断练习:用延时程序做闪烁灯
51单片机定时、中断练习:用延时程序做闪烁灯
在学单片机时我们第一个例子就是灯的闪烁,那是用做的,现在回想起来,这样做不很恰当,为什么呢?我们的主程序做了灯的闪烁,就不能再干其它的事了,难道单片机只能这样工作吗?当然不是,我们可以用定时器来实现灯的闪烁的功能。例1:查询方式ORG0000HAJMPSTARTORG30HSTART:MOVP1,#0FFH;关所灯MOVTMOD,#B;定时/计数器0工作于方式1MOVTH0,#15HMOVTL0,#0A0H;即数5536SETBTR0;定时/计数器0开始运行LOOP:JBCTF0,NEXT;如果TF0等于1,则清TF0并转NEXT处AJMPLOOP;否则跳转到LOOP处运行NEXT:CPLP1.0MOVTH0,#15HMOVTL0,#9FH;重置定时/计数器的初值AJMPLOOPENDAJMPLOOPEND键入程序,看到了什么?灯在闪烁了,这可是用定时器做的,不再是主程序的循环了。简单地分析一下程序,为什么用JBC呢?TF0是定时/计数器0的溢出标记位,当定时器产生溢出后,该位由0变1,所以查询该位就可知宇时时间是否已到。该位为1后,要用软件将标记位清0,以便下一次定时是间到时该位由0变1,所以用了JBC指令,该指位在判1转移的同时,还将该位清0。以上程序是可以实现灯的闪烁了,可是主程序除了让灯闪烁外,还是不能做其他的事啊!不,不对,我们可以在LOOP:……和AJMP LOOP指令之间插入一些指令来做其他的事情,只要保证执行这些指令的时间少于定时时间就行了。那我们在用软件的时候不是也可以用一些指令来替代DJNZ吗?是的,但是那就要求你精确计算所用指令的时间,然后再减去相应的DJNZ循环次数,很不方便,而现在只要求所用指令的时间少于定时时间就行,显然要求低了。当然,这样的方法还是不好,所以我们常用以下的方法来实现。程序2:用中断实现ORG0000HAJMPSTARTORG000BH;定时器0的中断向量地址AJMPTIME0;跳转到真正的定时器程序处ORG30HSTART:MOVP1,#0FFH;关所灯MOVTMOD,#B;定时/计数器0工作于方式1MOVTH0,#15HMOVTL0,#0A0H;即数5536SETBEA;开总中断允许SETBET0;开定时/计数器0允许SETBTR0;定时/计数器0开始运行LOOP:AJMPLOOP;真正工作时,这里可写任意程序TIME0:;定时器0的中断处理程序PUSHACCPUSHPSW;将PSW和ACC推入堆栈保护CPLP1.0MOVTH0,#15HMOVTL0,#0A0H;重置定时常数POPPSWPOPACCRETIEND上面的例子中,定时时间一到,TF0由0变1,就会引发中断,CPU将自动转至000B处寻找程序并执行,由于留给定时器中断的空间只有8个字节,显然不足以写下所有有中断处理程序,所以在000B处安排一条跳转指令,转到实际处理中断的程序处,这样,中断程序可以写在任意地方,也可以写任意长度了。进入定时中断后,首先要保存当前的一些状态,程序中只演示了保存存ACC和PSW,实际工作中应该根据需要将可能会改变的单元的值都推入堆栈进行保护(本程序中实际不需保存护任何值,这里只作个演示)。
尘埃粒子计数器相关文章:
分享给小伙伴们:
我来说两句……
最新技术贴
微信公众号二
微信公众号一帮忙写一个89c51单片机中断程序_百度知道
帮忙写一个89c51单片机中断程序
请帮帮写一个89c52单片机中断程序:P1^0;P1^1;两个端口以一秒的频率闪烁,当;P3^2;口低电平时,P1^5;输出低电平,P1^3;P1^4;以0.5秒速度闪烁,15秒后结束,程序返回原来程序:P1^0;P1^1;两个端口继续以一秒的频率闪烁,等待;P3^2;第二次触发。全部程序细节,非...
请使用延时函数编写不要用定时器,
我有更好的答案
戒套用“俗语”,
晶振频率是多少?
这是晶振频率是11.0592mhz的
#include&&reg52.h&#define&unchar&unsigned&char#define&uint&unsigned&intsbit&LED0=P1^0;sbit&LED1=P1^1;sbit&LED3=P1^3;sbit&LED4=P1^4;sbit&LED5=P1^5;uint&time0,bit&void&init(){ TMOD=0x11; TH0=()/256; TL0=()%256; TH1=()/256; TL1=()%256; EA=1; EX0=1; ET0=1; ET1=1; TR0=0; TR1=1;}void&main(){ init(); while(1);}void&intp()&interrupt&0{ EX0=0; TR0=1; TR1=1; flag=1; LED0=1; LED1=1; LED5=0;}void&led0()&interrupt&1{ TH0=()/256; TL0=()%256; time0++; if(time0&=299) {
LED5=1; }}void&led1()&interrupt&3{ TH1=()/256; TL1=()%256; if(flag==0) {
if(time&=19)
LED0=~LED0;
LED1=~LED1;
} } else {
if(time&=9)
LED3=~LED3;
LED4=~LED4;
} }} 程序已经用单片机调试成功
为您推荐:
其他类似问题
您可能关注的内容
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。

我要回帖

更多关于 单片机定时中断 的文章

 

随机推荐