您好,登錄后才能下訂單哦!
本文實例講述了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.jb51.net/code/unixtime
更多關于Android相關內容感興趣的讀者可查看本站專題:《Android日期與時間操作技巧總結》、《Android開發入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。