Android编程计算函数时间戳的相关方法总结

Android编程计算函数时间戳的相关方法总结,第1张

概述本文实例讲述了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 ( "kernel7The current date/time is: %lld\n",time.tv_sec * 1000 + time.tv_usec /1000);}

#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);
里面,可以通过rtc,跟上层应用的时间对应起来,如下面的例子:

import java.text.SimpleDateFormat;SimpleDateFormat mFormat = new java.text.SimpleDateFormat("yyyy:MM:dd HH:mm:ss:SSS");String time = mFormat.format(System.currentTimeMillis());

当然过从java到native到kernel一个流程跟下去,有可能会发现user space里面的耗时比较多,而kernel里面却没有耗时的情况,这是因为有进程调度的存在。最近就遇到了这样的问题,user space一个函数耗时30ms,但是在kernel里面却没有花时间,因为从kernel返回到user space的时候,进行了进程调度,而此时的user space的thread block了,才会产生这样的情况,希望注意。

Java得到当前的年月日,时分秒格式的时间

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);

Native得到当前的年月日,时分秒格式的时间

PS:本站还提供了一个Unix时间戳转换工具,包含了各种常见语言针对时间戳的 *** 作方法,提供给大家参考:

到现今为止,终于把AndroID Java、Native、Kernel的时间时间对应起来了,对做系统性能的人来说,这是多么重要的事情呀!

Unix时间戳(timestamp)转换工具:
http://tools.jb51.net/code/unixtime

更多关于AndroID相关内容感兴趣的读者可查看本站专题:《Android日期与时间 *** 作技巧总结》、《Android开发入门与进阶教程》、《Android多媒体 *** 作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家AndroID程序设计有所帮助。

总结

以上是内存溢出为你收集整理的Android编程计算函数时间戳的相关方法总结全部内容,希望文章能够帮你解决Android编程计算函数时间戳的相关方法总结所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1146223.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-31
下一篇2022-05-31

发表评论

登录后才能评论

评论列表(0条)

    保存