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如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
焦点电影公司作品,电影焦点结局是什么?
潮流网站制作头像软件下载,适合母子的网名有哪些?
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
lovemo网页版地址 lovemo官网手机登录
网站制作壁纸教程视频,电脑壁纸网站?
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
如何用虚拟主机快速搭建网站?详细步骤解析
微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】
Laravel如何优化应用性能?(缓存和优化命令)
如何快速搭建高效WAP手机网站吸引移动用户?
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
如何在搬瓦工VPS快速搭建网站?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
免费视频制作网站,更新又快又好的免费电影网站?
高防服务器:AI智能防御DDoS攻击与数据安全保障
百度输入法ai组件怎么删除 百度输入法ai组件移除工具
Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】
laravel怎么通过契约(Contracts)编程_laravel契约(Contracts)编程方法
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
怎样使用JSON进行数据交换_它有什么限制
Win11怎么开启自动HDR画质_Windows11显示设置HDR选项
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
C++用Dijkstra(迪杰斯特拉)算法求最短路径
Laravel怎么清理缓存_Laravel optimize clear命令详解
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑
教你用AI将一段旋律扩展成一首完整的曲子
jquery插件bootstrapValidator表单验证详解
微信小程序 五星评分(包括半颗星评分)实例代码
如何在云主机上快速搭建网站?
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
如何在万网开始建站?分步指南解析
免费网站制作appp,免费制作app哪个平台好?
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
Thinkphp 中 distinct 的用法解析
Laravel如何实现模型的全局作用域?(Global Scope示例)
Laravel怎么集成Vue.js_Laravel Mix配置Vue开发环境
Swift中switch语句区间和元组模式匹配
Android 常见的图片加载框架详细介绍
Laravel如何实现API版本控制_Laravel版本化API设计方案
如何在阿里云虚拟服务器快速搭建网站?
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
Laravel如何使用Vite进行前端资源打包?(配置示例)

