symbian 时间使用和统计(计算)函数(类)运行时间
2011-01-05 16:08
453 查看
(1)TTime::HomeTime() / TTime::UniversalTime()
最常见的时间获取手段,精度不高;因涉及一定的运算过程,效率较低。适用于需要以常规“年月日时分秒”方式使用时间的场合。在EKA2平台下,其精度与低阶系统时钟(Nanokernel Timer)一致,通常为微妙级别。通过 HAL::Get(HAL::ENanoTickPeriod, result) 可以获的具体精度。
注意:它们使用的是系统时间,这是可以被其它进程修改的。
(2)User::TickCount()
传统的Tick计数器,精度通常仅为1/64秒(可能随硬件有差异),适用于精度要求较低的场合。通过 HAL::Get(HAL::ESystemTickPeriod, result) 可以获得具体精度。
注意:在休眠(Standby)状态下,TickCount将停止计数,所以User::TickCount()在休眠状态下将“损失”计时!
(3)User::NTickCount()
低阶系统时钟(Nanokernel Timer),通常提供微妙级Tick。通过 HAL::Get(HAL::ENanoTickPeriod, result) 可以获得具体精度。
注意:Symbian OS 6.x 没有此API。与TickCount不同的是,User::NTickCount()在休眠状态下不“损失”计时。
(4)User::FastCounter()
返回值类似于Tick,提供Symbian OS所能支持的最高精度,通常比TTime::HomeTime()更准确。(如果硬件不支持high resolution timer,则毫秒级时钟替代)而且,因为它采用快速的exec call读取一个硬件寄存器的数值,效率很高。通过 HAL::Get(HALData::EFastCounterFrequency, result) 可以获得其具体精度。
注意:在每次终端从休眠状态激活后,它将同步至正确的数值,也就是说User::FastCounter()在休眠状态下其实也是不“损失”计时的。
另外,User::After(), CPeriodic也会在休眠状态下“损失”计时,所以在手机这种特殊的应用环境中,需要特别注意不同定时器在“休眠”状态下计时的差异。
转者附加:
(2)中提到的方法如下
TInt period;
User::LeaveIfError(HAL::Get(HALData::ESystemTickPeriod, period));
TInt logMillisecsPerTick = period / 1000;
TBuf<50> text;
TInt timeInMillisecs = User::TickCount() * logMillisecsPerTick;
TInt secs = timeInMillisecs / 1000;
TInt millisecs = timeInMillisecs % 1000;
text.Num(secs);
text.Append('.');
text.Num(millisecs);// 秒.毫秒 精度通常仅为1/64秒(可能随硬件有差异)在模拟器上是1/100秒,
ShowTextOnScreen(text);
统计函数运行时间
1)
TTime lastTime;
TTime currentTime;
lastTime.HomeTime();
func();
currentTime.HomeTime();
#ifdef __SERIES60_30__
TInt64 timeLasted64 = ( currentTime.Int64() - lastTime.Int64() );
TUint timeLasted= (TUint)cnt64;
#else
TUint timeLasted= ( ( currentTime.Int64() - lastTime.Int64() ) ).Low();
#endif
最常见的时间获取手段,精度不高;因涉及一定的运算过程,效率较低。适用于需要以常规“年月日时分秒”方式使用时间的场合。在EKA2平台下,其精度与低阶系统时钟(Nanokernel Timer)一致,通常为微妙级别。通过 HAL::Get(HAL::ENanoTickPeriod, result) 可以获的具体精度。
注意:它们使用的是系统时间,这是可以被其它进程修改的。
(2)User::TickCount()
传统的Tick计数器,精度通常仅为1/64秒(可能随硬件有差异),适用于精度要求较低的场合。通过 HAL::Get(HAL::ESystemTickPeriod, result) 可以获得具体精度。
注意:在休眠(Standby)状态下,TickCount将停止计数,所以User::TickCount()在休眠状态下将“损失”计时!
(3)User::NTickCount()
低阶系统时钟(Nanokernel Timer),通常提供微妙级Tick。通过 HAL::Get(HAL::ENanoTickPeriod, result) 可以获得具体精度。
注意:Symbian OS 6.x 没有此API。与TickCount不同的是,User::NTickCount()在休眠状态下不“损失”计时。
(4)User::FastCounter()
返回值类似于Tick,提供Symbian OS所能支持的最高精度,通常比TTime::HomeTime()更准确。(如果硬件不支持high resolution timer,则毫秒级时钟替代)而且,因为它采用快速的exec call读取一个硬件寄存器的数值,效率很高。通过 HAL::Get(HALData::EFastCounterFrequency, result) 可以获得其具体精度。
注意:在每次终端从休眠状态激活后,它将同步至正确的数值,也就是说User::FastCounter()在休眠状态下其实也是不“损失”计时的。
另外,User::After(), CPeriodic也会在休眠状态下“损失”计时,所以在手机这种特殊的应用环境中,需要特别注意不同定时器在“休眠”状态下计时的差异。
转者附加:
(2)中提到的方法如下
TInt period;
User::LeaveIfError(HAL::Get(HALData::ESystemTickPeriod, period));
TInt logMillisecsPerTick = period / 1000;
TBuf<50> text;
TInt timeInMillisecs = User::TickCount() * logMillisecsPerTick;
TInt secs = timeInMillisecs / 1000;
TInt millisecs = timeInMillisecs % 1000;
text.Num(secs);
text.Append('.');
text.Num(millisecs);// 秒.毫秒 精度通常仅为1/64秒(可能随硬件有差异)在模拟器上是1/100秒,
ShowTextOnScreen(text);
统计函数运行时间
1)
TTime lastTime;
TTime currentTime;
lastTime.HomeTime();
func();
currentTime.HomeTime();
#ifdef __SERIES60_30__
TInt64 timeLasted64 = ( currentTime.Int64() - lastTime.Int64() );
TUint timeLasted= (TUint)cnt64;
#else
TUint timeLasted= ( ( currentTime.Int64() - lastTime.Int64() ) ).Low();
#endif
相关文章推荐
- symbian 时间使用和统计(计算)函数(类)运行时间
- symbian 时间使用和统计(计算)函数(类)运行时间
- 使用python装饰器计算函数运行时间
- 使用python装饰器计算函数运行时间的实例
- 计算程序运行的时间一个函数
- python装饰器计算函数运行时间
- 计算程序运行时间函数的选择
- golang一行代码计算函数运行时间
- Java当中计算关于程序运行时间的函数
- 函数时间计算——函数作为另一个函数的参数使用
- C# 统计函数运行时间
- 函数运行时间计算
- 使用console进行 性能测试 和 计算代码运行时间
- 增加测试函数计算排序函数运行时间
- 装饰器应用,Python模块学习之(__call__)实现准确计算函数运行时间
- C语言linux环境下使用gettimeofday函数得到程序运行时间
- 统计函数运行时间-CPU端
- oprofile 使用步骤 测试程序中各函数运行时间----步骤
- mysql的函数concat的,drop语句使用、列结构、所有变量、VERSION、CURRENT_DATE、支持selec+/ USER()支持详细时间计算方法
- opencv for python (7) 计算中值滤波函数程序的运行时间,及简要解释中值滤波函数