这是一个很重要的概念! 1.printf()的时间 在PC编程中,你可以用printf()这个函数来看变量值,而忽略它所占用的时间,(相对于3GHZ的CPU来说可以忽略),但是在嵌入式编程中,用printf()在超级终端中看变量值的时候,它的开销你要计算进去,尤其是程序对信号的捕捉到了毫秒,微秒级别的时候! 笔者曾经干过这样一件事情,用定时器函数来delay()9毫秒时间,过0.9毫秒,让里面的变量i加一,结果i等于9的时候跳出循环,而在里面多加了一句printf(),i加到了6就跳出了循环,害的我以为我的算法错了,希望大家不要走同样的弯路! 2.乘法时间 说到delay()函数,我的原型如下: void delay(double time)
{
delayEnd = 0; time = time * 12000;//得到计时次数
TCMPR0 = (long)time;
TCSR0 |= CEN; //开始计数 while(delayEnd == 0); //得到定时中断服务函数吧delayEnd 置为1
} 笔者用这个延迟函数想产生一个周期为26us的方波,于是delay(0.026);然后取反,结果产生了周期为100us的方波于是笔者改成了这样: void Delay(long time)
{
delayEnd = 0;
TCMPR0 = time; //得到计时次数
TCSR0 |= 0x40000000; //开始计数,对TCSR0的第30位尅是写1,表示计数 while(delayEnd == 0); //得到定时中断服务函数吧delayEnd 置为1
} 结果产生周期为50us的方波,从两个delay()函数中我们可以看到,乘法的占用时间在程序达到us级别的时候,是必须要简化和考虑的,而每条语句的汇编条数我们也要看到,尽量精简,因为延迟函数之前,程序的条数也会占用时间,这些在PC机中从来不用考虑!
|