延时是单片机入门必学的应用!
上一讲我们已经实现点亮一盏灯,但是很多时候程序的执行都是要死循环的,不能让程序像是停在那里不执行了。所以这一讲在前面的原理图基础上实现让LED2从点亮一段时间到熄灭一段时间再点亮一段时间如此循环下去,实现闪烁LED2的功能。
我们知道CPU执行一条语句是很快的,如果我们这样写程序来实现灯的闪烁:
#include <reg52.h> sbit LED2 = P0^0; sbit ADDR2 = P1^2; sbit ADDR1 = P1^1; sbit ADDR0 = P1^0; sbit ENLED = P1^4; sbit ADDR3 = P1^3; void main() { ADDR3 = 1;//使能三八译码器 ENLED = 0;// ADDR2 = 1;//************************** ADDR1 = 1;//让三八译码器的IO6输出低电平 ADDR0 = 0;//************************** while (1) { LED2=0;//点亮最右端的灯 LED2=1;//熄灭最右端的灯 } }
那我们看到的现象就是灯一直亮着,不会闪烁。原因就是执行“LED2=0;”把灯点亮之后执行“LED2=1;”去熄灭,但是这个熄灭语句只持续一瞬间就循环又开始执行“LED2=0;”了,熄灭状态的持续时间太短我们人眼也就观察不到闪烁的现象。
要想实现LED2闪烁,必须让LED2被点亮持续一段时间,被熄灭持续一段时间,也就是IO端口保持低电平一段时间,接着跳变保持高电平一段时间,此时我们需要用上延时。
#include <reg52.h> sbit LED2 = P0^0; sbit ADDR2 = P1^2; sbit ADDR1 = P1^1; sbit ADDR0 = P1^0; sbit ENLED = P1^4; sbit ADDR3 = P1^3; void main() { unsigned int i;//定义一个16位无符号整形变量 ADDR3 = 1;//使能三八译码器 ENLED = 0;// ADDR2 = 1;//************************** ADDR1 = 1;//让三八译码器的IO6输出低电平 ADDR0 = 0;//************************** while (1) { LED2=0;//点亮最右端的灯 for(i=0;i<30000;i++);//延时一段时间 LED2=1;//熄灭最右端的灯 for(i=0;i<30000;i++);//延时一段时间 } }
“for(i=0;i<30000;i++);”其实就是CPU空运行让i不断相加到30000之后不满足“i<30000”的判断条件就结束这条运行代码,接着去执行下一条语句了,通过占用CPU的执行时间来达到短暂的电平保持状态,也就能让LED2亮一小段时间,接着又灭一小段时间,这样LED2在while(1)的死循环下就实现不停循环的亮灭闪烁了。
对刚入门单片机编程的初学者来说,以前我们C语言基础上机操作的时候都是只见过别人int,char的去定义变量,而在单片机入门编程中看到的都是unsigned int,unsigned char这样定义,原因是单片机在入门的时候用的变量的取值都是0和正整数(正整数不包括0),所以才会用unsigned去定义无符号整形变量。
本文固定URL:https://www.dotcpp.com/course/180
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程