单片机实验2提示
2023-03-31 10:34:00 时间
参考程序,未必准确:
/*****************************************************************************
* 头文件 *
*****************************************************************************/
#include "8052.h"
#define LSA P1_5
#define LSB P1_6
#define LSC P1_7
unsigned int cnt=0;
unsigned char T0RH = 0; //T0 重载值的高字节
unsigned char T0RL = 0; //T0 重载值的低字节
signed char sec;
signed char sec_all=88;
signed char count=0;
unsigned char smgduan[]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0x0f8,0x80,0x90};
//共阳极的显示代码表0~9
void EXINT0() __interrupt 0;
void Timer0() __interrupt 1;
/*****************************************************************************
* 初始化和功能函数 *
*****************************************************************************/
/* 配置T0, ms-T0定时时间 */
void ConfigTimer0(unsigned int ms)
{
unsigned long tmp; //临时变量
tmp = 11059200 / 12; //定时器计数频率
tmp = (tmp * ms) / 1000; //计算所需的计数值
tmp = 65536 - tmp; //计算定时器重载值
tmp = tmp + 18; //补偿中断响应延时造成的误差
T0RH = (unsigned char)(tmp>>8); //定时器重载值拆分为高低字节
T0RL = (unsigned char)tmp;
TMOD &= 0xF0; //清零 T0 的控制位
TMOD |= 0x01; //配置 T0 为模式 1
TH0 = T0RH; //加载 T0 重载值
TL0 = T0RL;
ET0 = 1; //使能 T0 中断
}
void EXINT0() __interrupt 0
{
count++;
}
void Timer0() __interrupt 1
{
TH0 = T0RH; //重新加载重载值
TL0 = T0RL;
cnt++; //中断次数加1
if (cnt >= 100) //中断100次=1s
{
cnt = 0;
sec--;
if (sec < 0) //当显示值到0后,闪烁
{
sec = 0;
}
}
}
void LedScan(unsigned char pos,unsigned char dispcode)
{
unsigned char i;
for(i=0;i<=pos;i++)
{
switch(pos) //位选,选择点亮的数码管,
{
case(0):
LSA=1;LSB=0;LSC=0; break; //显示
case(1):
LSA=0;LSB=1;LSC=0; break; //显示第1位
case(2):
LSA=1;LSB=1;LSC=0; break; //显示第2位
case(3):
LSA=0;LSB=0;LSC=1; break; //显示第3位
}
P0=dispcode; //发送段码
}
}
void sys_init(void)
{
LSA = 0;
LSB = 0;
LSC = 0;
cnt = 0; //中断次数计数器
sec = sec_all; //秒数初值
ConfigTimer0(10); //配置 T0 定时 10ms
EA=1; //开中断
IT0=0;
EX0=1;
// IT1=1;
// EX1=1;
// PX1=1;
TR0=1;
}
/*****************************************************************************
* 主函数 *
*****************************************************************************/
void main(void)
{
sys_init();
while(1)
{
if(count%2==0)
{
TR0 = 1;
}
else
{
TR0 = 0;
}
if((cnt>49)&&(sec==0))
{
LedScan(0,0xff); //显示个位值
LedScan(1,0xff); //显示个位值
}
else
{
LedScan(0,smgduan[sec%10]); //显示个位值
LedScan(1,smgduan[sec/10]); //显示十位值
}
}
}
相关文章
- 谷歌发布新编程语言,专治SQL各种“不服”
- JavaEE中遗漏的10个最重要的安全控制
- 如何在O(1)内找到实时序列的最小值?
- Seata 分布式事务 XA 与 AT 全面解析
- 绝了!这个MySQL故障定位方法太好用了
- Redis 高可用篇:Cluster 集群能支撑的数据有多大?
- Websocket库Ws原理分析
- 《吃透 MQ 系列》之打通 Kafka 的任督二脉
- 谷歌这个牛逼的开源数据库,我居然等到它上Github热榜才发现
- 热点推荐:2016年热门技术方向预测
- 一文搞定消息队列(MQ)之生产者-消费者
- 穷人的量子比特:量子计算机太难造了,先试试概率计算机?
- 字节前端都知道的CSS包含块规则
- 第一个世界量子日,量子计算大牛Scott Aaronson获颁ACM计算奖
- 全栈CMS系统服务端启动细节复盘
- Netfileter & Iptables 实现之 Netfilter实现
- 双写兜兜转转,又回到了串行化的方式
- 不停止 MySQL 服务增加从库的两种方式
- 本科作业到Nature子刊:大二学生突破量子计算近20年的纠错码难题
- 压缩版styleGAN,合成高保真图像,参数更少、计算复杂度更低