Android编程计算函数时间戳的相关方法总结
本文实例讲述了Android编程计算函数时间戳的相关方法。分享给大家供大家参考,具体如下:
对于做性能的人来说,知道时间的花在哪了是比较重要的,可以在函数前后得到系统的时间,计算时间戳能够得到每个函数的时间。
在JAVA中可以通过System.currentTimeMillis()得到:
longstart_time=System.currentTimeMillis(); View.draw(canvas); longend_time=System.currentTimeMillis(); longspend_time=end_time-start_time; Log.i(TAG,"mView.draw:spend_time="+spend_time);
在native的代码中,可以通过下面的方式得到函数的执行时间:
#include#include voidmain() { structtimevaltime; gettimeofday(&time,NULL); printf("\007Thecurrentdate/timeis:%lld\n",time.tv_sec*1000+time.tv_usec/1000); }
在kernel里面,可以通过rtc,跟上层应用的时间对应起来,如下面的例子:
#include#include structtimespectime_start,time_end; structrtc_timetm_start,tm_end; longtime_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.%09luUTC)\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"\ntid:%d,common:%s\n",current->pid,current->comm); printk(KERN_ERR"\nend(%d-%02d-%02d%02d:%02d:%02d.%09luUTC)\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"\nmdss_fb_commit_wq_handlerend,time_nsec:%ld\n",time_nsec);
当然过从java到native到kernel一个流程跟下去,有可能会发现userspace里面的耗时比较多,而kernel里面却没有耗时的情况,这是因为有进程调度的存在。最近就遇到了这样的问题,userspace一个函数耗时30ms,但是在kernel里面却没有花时间,因为从kernel返回到userspace的时候,进行了进程调度,而此时的userspace的threadblock了,才会产生这样的情况,希望注意。
Java得到当前的年月日,时分秒格式的时间
importjava.text.SimpleDateFormat; SimpleDateFormatmFormat=newjava.text.SimpleDateFormat("yyyy:MM:ddHH:mm:ss:SSS"); Stringtime=mFormat.format(System.currentTimeMillis());
Native得到当前的年月日,时分秒格式的时间
timevaltv; gettimeofday(&tv,NULL); intmilli=tv.tv_usec/1000; charbuffer[80]; strftime(buffer,80,"%Y:%m:%d%H:%M:%S",localtime(&tv.tv_sec)); charcurrentTime[84]=""; sprintf(currentTime,"%s.%d",buffer,milli); ALOGD("time:%s\n",currentTime);
到现今为止,终于把AndroidJava、Native、Kernel的时间时间对应起来了,对做系统性能的人来说,这是多么重要的事情呀!
PS:本站还提供了一个Unix时间戳转换工具,包含了各种常见语言针对时间戳的操作方法,提供给大家参考:
Unix时间戳(timestamp)转换工具:
http://tools.jb51.net/code/unixtime
更多关于Android相关内容感兴趣的读者可查看本站专题:《Android日期与时间操作技巧总结》、《Android开发入门与进阶教程》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》
希望本文所述对大家Android程序设计有所帮助。