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

发布时间 - 2026-01-11 01:10:50    点击率:

本文实例讲述了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)转换工具:
http://tools./code/unixtime

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

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


# Android  # 计算  # 函数  # 时间戳  # Android studio 运行main 函数的方法  # 详解Android应用main函数的调用  # Android Studio生成函数注释的实现方法  # Android自定义View的三个构造函数  # Android自定义view 你所需要知道的基本函数总结  # Android 自定义View的构造函数详细介绍  # Android编程之匿名内部类与回调函数用法分析  # Android自定义View构造函数详解  # Android Chronometer控件实现计时器函数详解  # Android nativePollOnce函数解析  # 可以通过  # 的人  # 却没有  # 给大家  # 转换工具  # 进阶  # 这是  # 操作技巧  # 相关内容  # 才会  # 执行时间  # 感兴趣  # 比较多  # 这是因为  # 更多关于  # 所述  # 现今  # 程序设计  # 花在  # 进行了 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现API资源集合?(Resource Collection教程)  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  详解阿里云nginx服务器多站点的配置  详解CentOS6.5 安装 MySQL5.1.71的方法  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  Laravel怎么发送邮件_Laravel Mail类SMTP配置教程  网站制作免费,什么网站能看正片电影?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  如何在企业微信快速生成手机电脑官网?  Laravel如何实现全文搜索功能?(Scout和Algolia示例)  如何快速建站并高效导出源代码?  如何在阿里云香港服务器快速搭建网站?  谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  javascript如何操作浏览器历史记录_怎样实现无刷新导航  ,南京靠谱的征婚网站?  Laravel怎么为数据库表字段添加索引以优化查询  javascript基于原型链的继承及call和apply函数用法分析  PHP正则匹配日期和时间(时间戳转换)的实例代码  JavaScript如何实现类型判断_typeof和instanceof有什么区别  利用vue写todolist单页应用  魔方云NAT建站如何实现端口转发?  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  开心动漫网站制作软件下载,十分开心动画为何停播?  Swift中循环语句中的转移语句 break 和 continue  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  安克发布新款氮化镓充电宝:体积缩小 30%,支持 200W 输出  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  HTML 中动态设置元素 name 属性的正确语法详解  javascript中闭包概念与用法深入理解  Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  nodejs redis 发布订阅机制封装实现方法及实例代码  Laravel如何集成Inertia.js与Vue/React?(安装配置)  如何快速搭建二级域名独立网站?  node.js报错:Cannot find module &#39;ejs&#39;的解决办法  Laravel如何生成API文档?(Swagger/OpenAPI教程)  HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  微信小程序 wx.uploadFile无法上传解决办法  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  Laravel如何发送系统通知?(Notification渠道示例)  简历没回改:利用AI润色让你的文字更专业  公司门户网站制作流程,华为官网怎么做?  新三国志曹操传主线渭水交兵攻略  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法