c语言中的精确延时程序举例

c语言中的精确延时程序举例

ID:8802473

大小:30.00 KB

页数:3页

时间:2018-04-08

c语言中的精确延时程序举例_第1页
c语言中的精确延时程序举例_第2页
c语言中的精确延时程序举例_第3页
资源描述:

《c语言中的精确延时程序举例》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、c语言中的精确延时程序举例我在网上到看了一些关于延时的讨论,其中有篇文章51单片机KeilC延时程序的简单研究,作者:InfiniteSpaceStudio/isjfk写得不错,他是用while(--i);产生DJNZ来实现精确延时,后来有人说如果while里面不能放其它语句,否则也不行,用do-while就可以,具体怎样我没有去试.所有这些都没有给出具体的实例程序来.还看到一些延时的例子多多少少总有点延时差.为此我用for循环写了几个延时的子程序贴上来,希望能对初学者有所帮助.(晶振12MHz,一个机器周期1us.)一. 500ms延时子程序程序:voiddelay500ms(void

2、){unsignedchari,j,k;for(i=15;i>0;i--)for(j=202;j>0;j--)for(k=81;k>0;k--);}产生的汇编:C:0x08007F0FMOVR7,#0x0FC:0x08027ECAMOVR6,#0xCAC:0x08047D51MOVR5,#0x51C:0x0806DDFEDJNZR5,C:0806C:0x0808DEFADJNZR6,C:0804C:0x080ADFF6DJNZR7,C:0802C:0x080C22RET计算分析:程序共有三层循环一层循环n:R5*2=81*2=162usDJNZ2us二层循环m:R6*(n+3)= 202

3、*165=33330usDJNZ2us+R5赋值1us=3us三层循环:R7*(m+3)=15*33333= 499995usDJNZ2us+R6赋值1us=3us循环外:5us子程序调用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、汇编C:0x08007F05MOVR7,#0x05C:0x08027E84MOVR6,#0x84C:0x08047D96MOVR5,#0x96C:0x0806DDFEDJNZR5,C:0806C:0x0808DEFADJNZR6,C:0804C:0x080ADFF6DJNZR7,C:0802C:0x080C22RET三.10ms延时子程序程序:voiddelay10ms(void){unsignedchari,j,k;for(i=5;i>0;i--)for(j=4;j>0;j--)for(k=248;k>0;k--);}产生的汇编C:0x08007F05MOVR7,#0x05C:0x08

5、027E04MOVR6,#0x04C:0x08047DF8MOVR5,#0xF8C:0x0806DDFEDJNZR5,C:0806C:0x0808DEFADJNZR6,C:0804C:0x080ADFF6DJNZR7,C:0802C:0x080C22RET四.1s延时子程序程序:voiddelay1s(void){unsignedcharh,i,j,k;for(h=5;h>0;h--)for(i=4;i>0;i--)for(j=116;j>0;j--)for(k=214;k>0;k--);}产生的汇编C:0x08007F05MOVR7,#0x05C:0x08027E04MOVR6,#0x

6、04C:0x08047D74MOVR5,#0x74C:0x08067CD6MOVR4,#0xD6C:0x0808DCFEDJNZR4,C:0808C:0x080ADDFADJNZR5,C:0806C:0x080CDEF6DJNZR6,C:0804C:0x080EDFF2DJNZR7,C:0802C:0x081022RET在精确延时的计算当中,最容易让人忽略的是计算循环外的那部分延时,在对时间要求不高的场合,这部分对程序不会造成影响.

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

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

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