欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android編程計算函數時間戳的相關方法總結

 更新時間:2017年05月19日 09:52:19   作者:歐軍禮  
這篇文章主要介紹了Android編程計算函數時間戳的相關方法,結合實例形式總結分析了Android Java、Native、Kernel時間戳計算相關操作技巧,需要的朋友可以參考下

本文實例講述了Android編程計算函數時間戳的相關方法。分享給大家供大家參考,具體如下:

對于做性能的人來說,知道時間的花在哪了是比較重要的,可以在函數前后得到系統(tǒng)的時間,計算時間戳能夠得到每個函數的時間。

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的代碼中,可以通過下面的方式得到函數的執(zhí)行時間:

#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一個流程跟下去,有可能會發(fā)現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的時間時間對應起來了,對做系統(tǒng)性能的人來說,這是多么重要的事情呀!

PS:本站還提供了一個Unix時間戳轉換工具,包含了各種常見語言針對時間戳的操作方法,提供給大家參考:

Unix時間戳(timestamp)轉換工具:
http://tools.jb51.net/code/unixtime

更多關于Android相關內容感興趣的讀者可查看本站專題:《Android日期與時間操作技巧總結》、《Android開發(fā)入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控件用法總結

希望本文所述對大家Android程序設計有所幫助。

相關文章

  • android view實現橫向滑動選擇

    android view實現橫向滑動選擇

    這篇文章主要為大家詳細介紹了android view實現橫向滑動選擇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Android?殺死進程幾種方法詳細介紹

    Android?殺死進程幾種方法詳細介紹

    這篇文章主要介紹了Android?殺死進程的相關資料,并整理了幾種實現方法,及具體實現的代碼,需要的朋友可以參考下
    2016-11-11
  • 學習Android Handler消息傳遞機制

    學習Android Handler消息傳遞機制

    這篇文章主要為大家詳細介紹了Android Handler消息傳遞機制,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Android輪播圖點擊圖片放大效果的實現方法

    Android輪播圖點擊圖片放大效果的實現方法

    這篇文章主要給大家介紹了關于Android輪播圖點擊圖片放大效果的實現方法,文中通過示例代碼介紹的非常詳細,對各位Android開發(fā)者們具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • Android實現屏幕旋轉四個方向準確監(jiān)聽

    Android實現屏幕旋轉四個方向準確監(jiān)聽

    這篇文章主要為大家詳細介紹了Android實現屏幕旋轉四個方向準確監(jiān)聽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 詳解如何在Flutter中用小部件創(chuàng)建響應式布局

    詳解如何在Flutter中用小部件創(chuàng)建響應式布局

    由于Flutter的跨平臺、單一代碼庫的能力,了解屏幕管理以防止像柔性溢出錯誤或糟糕的用戶界面設計這樣的問題是至關重要的。本文將探討如何用靈活和擴展的小部件創(chuàng)建響應式布局,需要的可以參考一下
    2022-02-02
  • Android ListView中動態(tài)添加RaidoButton的實例詳解

    Android ListView中動態(tài)添加RaidoButton的實例詳解

    這篇文章主要介紹了Android ListView中動態(tài)添加RaidoButton的實例詳解的相關資料,需要的朋友可以參考下
    2017-08-08
  • Android neon 優(yōu)化實踐示例

    Android neon 優(yōu)化實踐示例

    這篇文章主要為大家介紹了Android neon 優(yōu)化實踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Flutter下Android Studio配置gradle的方法

    Flutter下Android Studio配置gradle的方法

    這篇文章主要介紹了Flutter下Android Studio配置gradle的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • Android開發(fā)SavedState?Jetpack狀態(tài)保存利器

    Android開發(fā)SavedState?Jetpack狀態(tài)保存利器

    這篇文章主要為大家介紹了Android開發(fā)SavedState?Jetpack狀態(tài)保存利器使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08

最新評論