51单片机C语言程序中延时函数delay的原理是什么?
现在找到两个函数第一:voiddelay(void){unsignedinti,j;for(i=0;i<500;i++){for(j=0;j<121;j++){;}}}第...
现在找到两个函数
第一:
void delay(void)
{ unsigned int i,j;
for(i=0;i<500;i++)
{ for(j=0;j<121;j++)
{;}
}
}
第二:
void delay(unsigned int k)
{ unsigned int i,j;
for(i=0;i<k;i++)
{ for(j=0;j<121;j++)
{;}
}
}
现有几个疑问:
1:延时函数的原理?
2:两个for循环的作用?
3:i、j的取值有什么规律和依据?是不是和单片机接的晶振频率有关?所能延时的最小单位时间是怎么计算的?
延时时间怎么计算啊!假如用的是AT89C51RC+11.0592M的晶振呢? 展开
第一:
void delay(void)
{ unsigned int i,j;
for(i=0;i<500;i++)
{ for(j=0;j<121;j++)
{;}
}
}
第二:
void delay(unsigned int k)
{ unsigned int i,j;
for(i=0;i<k;i++)
{ for(j=0;j<121;j++)
{;}
}
}
现有几个疑问:
1:延时函数的原理?
2:两个for循环的作用?
3:i、j的取值有什么规律和依据?是不是和单片机接的晶振频率有关?所能延时的最小单位时间是怎么计算的?
延时时间怎么计算啊!假如用的是AT89C51RC+11.0592M的晶振呢? 展开
展开全部
原理:只是执行一些所谓的“无实际意义的指令”,如缩放或执行一个int自加,简单地说,就像高中数学中的“乘法原理”一样,很容易迅速增加上面提到的“无意义指令”的数量
关于大小的值:如果是在C语言中,该值不仅与水晶振动、单片机本身的速度,但也与C的编译器,所以,虽然这个值可以精确计算,但大多数情况下,程序员是经验值。
当然,如果你在汇编中编程,情况就不同了,因为每条指令使用一定数量的机器周期,你当然可以根据所有指令使用的总时间来计算特定延迟的总时间。
扩展资料:
定义延迟XMS毫秒的延迟函数
Voiddelay(unsignedintXMS)//XMS表示需要延迟的毫秒数
{
无符号intx,y;
For(x=XMS;X0;X-)
For(y=110;Y”0;Y-);
}
使用:
VoidDelay10us(ucharMs)
{
Uchar数据我;
(;女士“0;------Ms)
对于(I = 26)我> 0;我-);
}
I=[(延迟值-1.75)*12/ms-15]/4
展开全部
1:原理:仅仅执行一些,没有实质性影响的所谓“无意义指令”,比如做比大小啊,做某个int的自加运算啊之类的
2:两重for的作用:简单的说,就像高中数学中的“乘法原理”一样,这样可以很轻易的迅速增加上述“无意义指令”的数目
3:关于取值大小:这个如果是在C下变成,这个值不仅仅与晶振、单片机本身运算速度有关,而且还与C的编译器有关,所以说,这个值虽说是可以精确计算的,但大多数情况下,程序员用的都是“经验值”——当然,如果用汇编编程,情况就不一样了,因为每一条指令所使用的机器周期是一定的,你当然可以根据所有指令使用的总时间,精确的算出具体延时的总时间
综合你的的问题,我给你一点建议,就是刚学单片机的时候,还是一定要老老实实的从汇编编程学起——这样,在你以后接触到C之后,你才能明白,这中间实际上经历了一个什么样的过程,只有这样你才能真正理解单片机。当然,等最终你完全拿下一种单片机之后,尽量使用C编程,无疑是历史所肯定的。
具体有什么问题你还可以hi我
2:两重for的作用:简单的说,就像高中数学中的“乘法原理”一样,这样可以很轻易的迅速增加上述“无意义指令”的数目
3:关于取值大小:这个如果是在C下变成,这个值不仅仅与晶振、单片机本身运算速度有关,而且还与C的编译器有关,所以说,这个值虽说是可以精确计算的,但大多数情况下,程序员用的都是“经验值”——当然,如果用汇编编程,情况就不一样了,因为每一条指令所使用的机器周期是一定的,你当然可以根据所有指令使用的总时间,精确的算出具体延时的总时间
综合你的的问题,我给你一点建议,就是刚学单片机的时候,还是一定要老老实实的从汇编编程学起——这样,在你以后接触到C之后,你才能明白,这中间实际上经历了一个什么样的过程,只有这样你才能真正理解单片机。当然,等最终你完全拿下一种单片机之后,尽量使用C编程,无疑是历史所肯定的。
具体有什么问题你还可以hi我
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
延时函数是通过执行无意义的操作消耗CPU时间实现延时的,像以上的空循环。
C语言的for循环转换为汇编语言后会比较麻烦,但是延时时间基本是和循环次数成正比,和晶振频率成反比的。演示的最小时间单位应该就是函数跳转时间(要进行一些寄存器的入栈出栈操作)。
C语言的for循环转换为汇编语言后会比较麻烦,但是延时时间基本是和循环次数成正比,和晶振频率成反比的。演示的最小时间单位应该就是函数跳转时间(要进行一些寄存器的入栈出栈操作)。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
1),2)楼上已经说了
3)精确的延时时间最好看汇编代码来计算。和晶振当然有关。延时 ++i / i++ 是不同的。这种循环延时程序不能有中断。
C编译完了把汇编(Assemble)代码贴上来
3)精确的延时时间最好看汇编代码来计算。和晶振当然有关。延时 ++i / i++ 是不同的。这种循环延时程序不能有中断。
C编译完了把汇编(Assemble)代码贴上来
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
程序的执行是要消耗时间的 用for积累N个步骤的时间以达到延时
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询