开场白:
上一节鸿哥说到delay()延时函数耗费的时刻太长了,其它使命底子没有机会履行,咱们该怎样改进?本节教咱们使用累计主循环次数的办法来处理这个问题。这一节要教会咱们两个知识点:
榜首点:使用累计主循环次数的办法完成时刻延时
第二点:switch中心句子之初体会。 鸿哥一切的实战项目都是根据switch句子完成多使命并行处理。
(1)硬件渠道:根据朱兆祺51单片机学习板。
(2)完成功用:让一个LED闪耀。
(3)源代码解说如下:
#include “REG52.H”
/* 注释一:
* const_time_level是计算循环次数的设定上限,数值越大,LED延时的时刻越久
*/
#define const_time_level 10000
void initial_myself();
void initial_peripheral();
void delay_long(unsigned int uiDelaylong);
void led_flicker();
sbit led_dr=P3^5;
/* 注释二:
* 吴坚鸿个人的命名风格:但凡switch句子里边的过程变量后缀都是Step.
* 前缀带uc,ui,ul别离表明此变量是unsigned char,unsigned int,unsigned long.
*/
unsigned char ucLedStep=0; //过程变量
unsigned int uiTimeCnt=0; //计算循环次数的延时计数器
void main()
{
initial_myself();
delay_long(100);
initial_peripheral();
while(1)
{
led_flicker();
}
}
void led_flicker() ////第三区 LED闪耀应用程序
{
switch(ucLedStep)
{
case 0:
/* 注释三:
* uiTimeCnt累加循环次数,只有当它的次数大于或等于设定上限const_time_level时,
* 才会去改动LED灯的状况,不然CPU退出led_flicker()使命,持续快速扫描其他的使命,
* 这样的程序结构就可以到达多使命并行处理的意图。
* 本程序根据朱兆祺51单片机学习板
*/
uiTimeCnt++; //累加循环次数,
if(uiTimeCnt>=const_time_level) //时刻到
{
uiTimeCnt=0; //时刻计数器清零
led_dr=1; //让LED亮
ucLedStep=1; //切换到下一个过程
}
break;
case 1:
uiTimeCnt++; //累加循环次数,
if(uiTimeCnt>=const_time_level) //时刻到
{
uiTimeCnt=0; //时刻计数器清零
led_dr=0; //让LED灭
ucLedStep=0; //回来到上一个过程
}
break;
}
}
void delay_long(unsigned int uiDelayLong)
{
unsigned int i;
unsigned int j;
for(i=0;i { for(j=0;j<500;j++) //内嵌循环的空指令数量 { ; //一个分号相当于履行一条空句子 } } }
void initial_myself() //榜首区 初始化单片机
{
led_dr=0; //LED灭
}
void initial_peripheral() //第二区 初始化外围
{
; //本例为空
}
总结陈词:
在实践项目中,用累计主循环次数完成时刻延时是一个不错的挑选。这种办法能担任多使命处理的程序结构,可是它本身也有一个小小的缺乏。跟着主函数里使命量的添加,咱们为了确保延时时刻的准确性,要不断批改设定上限const_time_level 。咱们该怎样处理这个问题呢?欲知概况,请听下回分解—–累计守时中止次数使LED灯闪耀。