工业控制 | 能源技术 | 汽车电子 | 通信网络 | 安防监控 | 智能电网 | 移动手持 | 无线技术 | 家用电器 | 数字广播 | 消费电子 | 应用软件 | 其他方案

电路设计->综合电路图->嵌入式系统电路图->嵌入式C实现延时程序的不同变量的区别

嵌入式C实现延时程序的不同变量的区别

作者:angelazhang时间:2015-06-24浏览次数:1469

在嵌入式系统中,延时是经常需要使用的一种手段,延时的方法可以通过使用类似于"NOP"的指令来实现,但是如果延时的时间比较 长,如果使用太多的"NOP"指令则会消耗过多的储存空间,最好的方法是使用子程序(汇编语言中)或子函数(高级语言中)。当然这里并不打算讨论如果使用 定时器中断来实现延时。下面就在C语言中使用子函数实现延时的几个问题做些讨论,当然讨论高级语言的延时就需要考虑编译器和处理器,这里为了讨论的方便, 而且不失一般性,可以用标准51单片机作处理器和uVision2作为编译环境,晶振为12MHz,这样一个标准的机器周期即为1uS。其他的情况则可以据此类推。

 

先看一段延时程序:其中Delay1()与Delay2()两者的型参类型不同。

 

 

将上述的Delay1(100)(变量为unsignedint类型)或Delay2(100)(变量为unsignedchar类型)分别在两次过程中执行,便会得到了下述的执行结果:

 

 

断点B减去断点A的时间为810uS,这个时间即为执行Delay1(100)所花费的时间;

 

 

断点B减去断点A的时间为608uS,这个时间即为执行Delay2(100)所花费的时间;

 

由此可见,作为unsignedint变量类型来传递延时函数的参数,会增长延时的时间,而使用unsignedchar变量类型则会得到短的延时时 间。我们都知道C语言经过编译后是要转化成汇编语言的,只有汇编语句才有精确的执行时间,所以要知道这两者结果的不同,原因就在于他们经过编译之后汇编语 句的不同的地方。



评论

技术专区