单片机C语言(for)延时计算

单片机C语言(for)延时计算

ID:38229822

大小:34.00 KB

页数:4页

时间:2019-05-28

单片机C语言(for)延时计算_第1页
单片机C语言(for)延时计算_第2页
单片机C语言(for)延时计算_第3页
单片机C语言(for)延时计算_第4页
资源描述:

《单片机C语言(for)延时计算》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、C程序中可使用不同类型的变量来进行延时设计。经实验测试,使用unsignedchar类型具有比unsignedint更优化的代码,在使用时应该使用unsignedchar作为延时变量。 以某晶振为12MHz的单片机为例,晶振为12MHz即一个机器周期为1us。一.500ms延时子程序程序:    voiddelay500ms(void)      {      unsignedchari,j,k;        for(i=15;i>0;i--)        for(j=202;j>0;j--

2、)        for(k=81;k>0;k--);      } 计算分析:    程序共有三层循环    一层循环n:R5*2=81*2=162us                  DJNZ  2us    二层循环m:R6*(n+3)=202*165=33330us          DJNZ  2us+R5赋值1us=3us    三层循环:R7*(m+3)=15*33333=499995us        DJNZ  2us+R6赋值1us=3us    循环外:  5us    

3、        子程序调用2us+子程序返回2us+R7赋值1us  =5us    延时总时间=三层循环+循环外=499995+5=500000us=500ms计算公式:延时时间=[(2*R5+3)*R6+3]*R7+5    二.200ms延时子程序程序:voiddelay200ms(void){      unsignedchari,j,k;        for(i=5;i>0;i--)        for(j=132;j>0;j--)        for(k=150;k>0;k--

4、);}    三.10ms延时子程序程序:voiddelay10ms(void){      unsignedchari,j,k;        for(i=5;i>0;i--)        for(j=4;j>0;j--)        for(k=248;k>0;k--);}    四.1s延时子程序程序:voiddelay1s(void){      unsignedcharh,i,j,k;        for(h=5;h>0;h--)        for(i=4;i>0;i--) 

5、       for(j=116;j>0;j--)        for(k=214;k>0;k--);}关于单片机C语言的精确延时,网上很多都是大约给出延时值没有准确那值是多少,也就没有达到精确高的要求,而本函数克服了以上缺点,能够精确计数出要延时值且精确达到1us,本举例所用CPU为STC12C5412系列12倍速的单片机,只要修改一下参数值其它系例单片机也通用,适用范围宽。 共有三条延时函数说明如下:函数调用分两级:一级是小于10US的延时,二级是大于10US的延时//==========

6、==========小于10US的【用1US级延时】====================//----------微秒级延时---------for(i=X;i>X;i--)延时时间=(3+5*X)/12  提示(单位us, X不能大于255) //================大于10US<小于21.9955Ms的可用【10US级延时函数】===========voidDelay10us(ucharMs){   uchardatai;   for(;Ms>0;Ms--)          

7、             for(i=26;i>0;i--);}i=[(延时值-1.75)*12/Ms-15]/4如想延时60US则 i=[(60-1.75)*12/6-15]/4=25.375≈26;修改i的值=26,再调用上面的【10US级延时函数】Delay10us(6);则就精确延时60US;如果想延时64US可以用这二种函数组合来用:Delay10us(6);for(i=9;i>X;i--) 共延时64US

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。