- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实训报告
题 目
年 级 专 业
班 级 学 号
姓 名
地 点
日 期 定时器中断入口 重置计数初值 中断次数加1 中断次数等于2? 中断次数清零,0.01秒位加1 0.01秒位到10? 0.01秒位清零,0.1秒位加1 0.1秒位到10? 0.1秒位清零,1秒位加1 1秒位到10? 1秒位清零,10秒位加1 10秒位到10? 10秒位清零 中断返回。
2.3 程序清单
#includereg52.h
#define uint unsigned int
#define uchar unsigned char
void delay(uint); //延时程序
sbit k1=P3^4; //定义开始键
sbit k2=P3^5; //定义暂停键
sbit k3=P3^6; //定义清零键
sbit dula=P2^6;
sbit wela=P2^7;
uchar code table[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f};
uchar tt,i,j,k,l;
void display(uchar i,uchar j,uchar k,uchar l); //数码管显示数
void main()
{
tt=0;
i=0;
j=0;
k=0;
l=0; //数码管显示0
TMOD=0x01; //设置定时器为模式1
TH0=(65536-5000)/256; //给定时器赋定时初值
TL0=(65536-5000)%256;
EA=1; //开总中断
ET0=1; TR0=0;
while(1)
{
if(k1==0) //判断是否按下开始键
{
delay(10); //消抖
if(k1==0)
TR0=1;
}
if(k2==0) //判断是否按下暂停键
{
delay(10); //消抖
if(k2==0)
TR0=0;
}
if(k3==0) //判断是否按下清零键
{
delay(10);
if(k3==0)
{
i=0;j=0;k=0;l=0;
TR0=0; //清零
}
}
display(i,j,k,l); //数码管显示
}
}
void delay(uint z)
{
uint x,y;
for(x=100;x0;x--)
for(y=z;y0;y--); //延时
}
void exter0() interrupt 1 //定时器溢出中断
{
TH0=(65536-5000)/256; //重装计时初值
TL0=(65536-5000)%256;
tt++;
if(tt==2)
{
tt=0;
i++; //溢出两次,0.01秒位加1
if(i==10)
{
i=0;
j++; //0.01秒位到10,0.1位加1
}
if(j==10)
{
j=0;
k++; //0.1秒位到10,1秒位加1
}
if(k==10)
{
k=0;
l++; //1秒位到10,10秒位加1
}
if(l==10)
{
l=0; //10秒位到10,清零
}
}
}
void display(uchar i,uchar j,uchar k,uchar l)
{
dula=1;
P0=table[i]; //显示数值
dula=0;
wela=1;
P0=0xf7; //0.01秒位显示
wela=0;
delay(1);
dula=1; //数值显示
P0=table[j];
dula=0;
wela=1;
P0=0xfb; //0.1秒位显示
wela=0;
delay(1);
dula=1; //数值显示
P0=table[k]|0x80; //始终在1秒位后面显示小数点
dula=0;
wela=1;
P0
文档评论(0)