欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Android編程計算函數(shù)時間戳的相關(guān)方法總結(jié)

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

創(chuàng)新互聯(lián)從2013年開始,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目網(wǎng)站制作、網(wǎng)站設(shè)計網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元咸寧做網(wǎng)站,已為上家服務(wù),為咸寧各地企業(yè)和個人服務(wù),聯(lián)系電話:13518219792

對于做性能的人來說,知道時間的花在哪了是比較重要的,可以在函數(shù)前后得到系統(tǒng)的時間,計算時間戳能夠得到每個函數(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í)行時間:

#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)用的時間對應(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);

當然過從java到native到kernel一個流程跟下去,有可能會發(fā)現(xiàn)user space里面的耗時比較多,而kernel里面卻沒有耗時的情況,這是因為有進程調(diào)度的存在。最近就遇到了這樣的問題,user space一個函數(shù)耗時30ms,但是在kernel里面卻沒有花時間,因為從kernel返回到user space的時候,進行了進程調(diào)度,而此時的user space的thread block了,才會產(chǎn)生這樣的情況,希望注意。

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);

到現(xiàn)今為止,終于把Android Java、Native、Kernel的時間時間對應(yīng)起來了,對做系統(tǒng)性能的人來說,這是多么重要的事情呀!

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

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

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

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

標題名稱:Android編程計算函數(shù)時間戳的相關(guān)方法總結(jié)
當前URL:http://aaarwkj.com/article38/gipjpp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、網(wǎng)站策劃、軟件開發(fā)、App設(shè)計、品牌網(wǎng)站制作面包屑導航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
国产一区二区欧美日本| 国产亚洲高清国产拍精品| 欧美日韩国产另类在线视频| 成人在线免费观看视频国产| 欧美午夜一区二区电影| 日韩女同性一区二区三区| 国产传媒在线播放一区| 末满18周岁禁止观看| av免费在线观看麻豆| 国产成人激情自拍视频在线观看| 视频久久这里只有精品| 九九热最新视频免费看| 亚洲精品成人午夜久久| 欧美性色黄大片人与善| 五月婷婷丁香视频在线| 日本黄色三级三级三级| 国产精品国产精品国产| 国内不卡一区二区三区| 欧美日韩国产精品一区二区在线观看| 亚洲伦理第一页中文字幕| 欧美日韩一区二区综合性色| 日本美女激情在线观看| 日本一区二区精美视频| 午夜激情在线观看网页| 丰满人妻熟妇乱精品视频| 农村精品少妇久久久久久| 国产成人短视频在线播放| 五月婷婷丁香婷婷丁香| 亚洲综合偷拍日韩av| 岛国大片一区二区三区| 深夜日本福利在线观看| 久久精品91久久久| 亚洲另类偷拍校园伦理| 国产亚洲精品女人久久久| 国产自愉自愉免费精品七| 国产三级av高清一区二区| 91麻豆亚洲国产成人久久精品| 99久久伊人精品综合观看| 成人黄色暖暖韩日视频| 日本一区二区在线观看视频 | 98精品偷拍视频一区二区三区 |