Android编程计算函数时间戳的相关方法总结
本文实例讲述了android编程计算函数时间戳的相关方法。分享给大家供大家参考,具体如下:
对于做性能的人来说,知道时间的花在哪了是比较重要的,可以在函数前后得到系统的时间,计算时间戳能够得到每个函数的时间。
在java中可以通过system.currenttimemillis()
得到:
long start_time = system.currenttimemillis(); view.draw(canvas); long end_time = system.currenttimemillis(); long spend_time = end_time - start_time; log.i(tag,"mview.draw: spend_time = " + spend_time);
在native的代码中,可以通过下面的方式得到函数的执行时间:
#include <stdio.h> #include <sys/time.h> void main () { struct timeval time; gettimeofday(&time, null); printf ( "\007the current date/time is: %lld\n", time.tv_sec * 1000 + time.tv_usec /1000); }
在kernel里面,可以通过rtc,跟上层应用的时间对应起来,如下面的例子:
#include <linux/time.h> #include <linux/rtc.h> struct timespec time_start, time_end; struct rtc_time tm_start, tm_end; long time_nsec = 0; getnstimeofday(&time_start); rtc_time_to_tm(time_end.tv_sec, &tm_start); printk(kern_err "\n (%d-%02d-%02d %02d:%02d:%02d.%09lu utc)\n", tm_start.tm_year + 1900, tm_start.tm_mon + 1, tm_start.tm_mday, tm_start.tm_hour, tm_start.tm_min, tm_start.tm_sec, time_start.tv_nsec); ....... getnstimeofday(&time_end); rtc_time_to_tm(time_end.tv_sec, &tm_end); time_nsec = time_end.tv_nsec - time_start.tv_nsec; printk(kern_err "\n tid: %d, common: %s \n", current->pid, current->comm); printk(kern_err "\n end(%d-%02d-%02d %02d:%02d:%02d.%09lu utc)\n", tm_end.tm_year + 1900, tm_end.tm_mon + 1, tm_end.tm_mday, tm_end.tm_hour, tm_end.tm_min, tm_end.tm_sec, time_end.tv_nsec); printk(kern_err "\n mdss_fb_commit_wq_handler end, time_nsec : %ld \n" , time_nsec);
当然过从java到native到kernel一个流程跟下去,有可能会发现user space里面的耗时比较多,而kernel里面却没有耗时的情况,这是因为有进程调度的存在。最近就遇到了这样的问题,user space一个函数耗时30ms,但是在kernel里面却没有花时间,因为从kernel返回到user space的时候,进行了进程调度,而此时的user space的thread block了,才会产生这样的情况,希望注意。
java得到当前的年月日,时分秒格式的时间
import java.text.simpledateformat; simpledateformat mformat = new java.text.simpledateformat("yyyy:mm:dd hh:mm:ss:sss"); string time = mformat.format(system.currenttimemillis());
native得到当前的年月日,时分秒格式的时间
timeval tv; gettimeofday(&tv, null); int milli = tv.tv_usec / 1000; char buffer [80]; strftime(buffer, 80, "%y:%m:%d %h:%m:%s", localtime(&tv.tv_sec)); char currenttime[84] = ""; sprintf(currenttime, "%s.%d", buffer, milli); alogd("time: %s \n", currenttime);
到现今为止,终于把android java、native、kernel的时间时间对应起来了,对做系统性能的人来说,这是多么重要的事情呀!
ps:本站还提供了一个unix时间戳转换工具,包含了各种常见语言针对时间戳的操作方法,提供给大家参考:
unix时间戳(timestamp)转换工具:
更多关于android相关内容感兴趣的读者可查看本站专题:《android日期与时间操作技巧总结》、《android开发入门与进阶教程》、《android多媒体操作技巧汇总(音频,视频,录音等)》、《android基本组件用法总结》、《android视图view技巧总结》、《android布局layout技巧总结》及《android控件用法总结》
希望本文所述对大家android程序设计有所帮助。
下一篇: 网站优化中有几个重要的KPI指标?