Android編程計(jì)算函數(shù)時(shí)間戳的相關(guān)方法總結(jié)
本文實(shí)例講述了Android編程計(jì)算函數(shù)時(shí)間戳的相關(guān)方法。分享給大家供大家參考,具體如下:
對(duì)于做性能的人來說,知道時(shí)間的花在哪了是比較重要的,可以在函數(shù)前后得到系統(tǒng)的時(shí)間,計(jì)算時(shí)間戳能夠得到每個(gè)函數(shù)的時(shí)間。
在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的代碼中,可以通過下面的方式得到函數(shù)的執(zhí)行時(shí)間:
#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,跟上層應(yīng)用的時(shí)間對(duì)應(yīng)起來,如下面的例子:
#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);
當(dāng)然過從java到native到kernel一個(gè)流程跟下去,有可能會(huì)發(fā)現(xiàn)user space里面的耗時(shí)比較多,而kernel里面卻沒有耗時(shí)的情況,這是因?yàn)橛羞M(jìn)程調(diào)度的存在。最近就遇到了這樣的問題,user space一個(gè)函數(shù)耗時(shí)30ms,但是在kernel里面卻沒有花時(shí)間,因?yàn)閺膋ernel返回到user space的時(shí)候,進(jìn)行了進(jìn)程調(diào)度,而此時(shí)的user space的thread block了,才會(huì)產(chǎn)生這樣的情況,希望注意。
Java得到當(dāng)前的年月日,時(shí)分秒格式的時(shí)間
import java.text.SimpleDateFormat;
SimpleDateFormat mFormat = new java.text.SimpleDateFormat("yyyy:MM:dd HH:mm:ss:SSS");
String time = mFormat.format(System.currentTimeMillis());
Native得到當(dāng)前的年月日,時(shí)分秒格式的時(shí)間
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);
到現(xiàn)今為止,終于把Android Java、Native、Kernel的時(shí)間時(shí)間對(duì)應(yīng)起來了,對(duì)做系統(tǒng)性能的人來說,這是多么重要的事情呀!
PS:本站還提供了一個(gè)Unix時(shí)間戳轉(zhuǎn)換工具,包含了各種常見語言針對(duì)時(shí)間戳的操作方法,提供給大家參考:
Unix時(shí)間戳(timestamp)轉(zhuǎn)換工具:
http://tools.jb51.net/code/unixtime
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android日期與時(shí)間操作技巧總結(jié)》、《Android開發(fā)入門與進(jìn)階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對(duì)大家Android程序設(shè)計(jì)有所幫助。
- Android studio 運(yùn)行main 函數(shù)的方法
- 詳解Android應(yīng)用main函數(shù)的調(diào)用
- Android Studio生成函數(shù)注釋的實(shí)現(xiàn)方法
- Android自定義View的三個(gè)構(gòu)造函數(shù)
- Android自定義view 你所需要知道的基本函數(shù)總結(jié)
- Android 自定義View的構(gòu)造函數(shù)詳細(xì)介紹
- Android編程之匿名內(nèi)部類與回調(diào)函數(shù)用法分析
- Android自定義View構(gòu)造函數(shù)詳解
- Android Chronometer控件實(shí)現(xiàn)計(jì)時(shí)器函數(shù)詳解
- Android nativePollOnce函數(shù)解析
相關(guān)文章
淺談android性能優(yōu)化之啟動(dòng)過程(冷啟動(dòng)和熱啟動(dòng))
本篇文章主要介紹了淺談android性能優(yōu)化之啟動(dòng)過程(冷啟動(dòng)和熱啟動(dòng)) ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-08-08
浮動(dòng)AppBar中的textField焦點(diǎn)回滾問題解決
這篇文章主要為大家介紹了浮動(dòng)AppBar中的textField焦點(diǎn)回滾問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08
Android實(shí)現(xiàn)顏色漸變動(dòng)畫效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)顏色漸變動(dòng)畫效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Android開發(fā)VR實(shí)戰(zhàn)之播放360度全景視頻
這篇文章主要為大家詳細(xì)介紹了Android開發(fā)VR實(shí)戰(zhàn)之播放360度全景視頻,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12
Android 滑動(dòng)返回Activity的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android 滑動(dòng)返回Activity的實(shí)現(xiàn)代碼的相關(guān)資料,這里是訪微信滑動(dòng)返回主頁的功能,需要的朋友可以參考下2017-07-07
手把手教你實(shí)現(xiàn)Android編譯期注解
今天給大家介紹Android編譯期注解sdk的步驟以及注意事項(xiàng),并簡要分析了運(yùn)行時(shí)注解以及字節(jié)碼技術(shù)在生成代碼上與編譯期注解的不同與優(yōu)劣,感興趣的朋友一起看看吧2021-07-07
Android-Jetpack-Navigation組件使用示例
這篇文章主要介紹了Android-Jetpack-Navigation組件使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
Android RatingBar星星評(píng)分控件實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了Android RatingBar星星評(píng)分控件,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-06-06

