linux 進程的執行時間,Linux 獲取進程執行時間

Linux 獲取進程執行時間

1 前言

測試一個程序的執行時間, 時間包括用戶 CPU 時間系統 CPU 時間時鐘時間之前獲取之前時間都是在程序的 main 函數用 time 函數實現, 這個只能粗略的計算程序的執行時間, 不能準確的獲取其他時間在看 APUE 時, 書中有關程序時間測試程序, 非常正規, 提供這三個時間如是, 上網搜了一下, 進行總結一下

2 獲取方法

有兩種方法可以獲取, 第一種是用 time 命令, time 進程第二種是通過在程序中進行記錄, 首先利用 sysconf 函數獲取時鐘滴答數, 再用 times 獲取 tms 結構

查看 times 函數, man 2 tms, 得到 tms 結構定義和 times 函數聲明如下:structtms{

clock_ttms_utime;/* user time */

clock_ttms_stime;/* system time */

clock_ttms_cutime;/* user time of children */

clock_ttms_cstime;/* system time of children */

};#include

clock_ttimes(structtms*buf);

注意: 此處計算的時間是時鐘滴答數, 需要除以系統時鐘滴答數, 得出實際的秒數

3 測試例子:

測試程序如下:#include

#include

#include

#include

#defineBUFFER_SIZE4*1024

intmain()

{

intsc_clk_tck;

sc_clk_tck=sysconf(_SC_CLK_TCK);

structtms begin_tms,end_tms;

clock_tbegin,end;

system("date");

begin=times(&begin_tms);

sleep(2);

end=times(&end_tms);

printf("real time: %lf\n",(end-begin)/(double)sc_clk_tck);

printf("user time: %lf\n",

(end_tms.tms_utime-begin_tms.tms_utime)/(double)sc_clk_tck);

printf("sys time: %lf\n",

(end_tms.tms_stime-begin_tms.tms_stime)/(double)sc_clk_tck);

printf("child user time: %lf\n",

(end_tms.tms_cutime-begin_tms.tms_cutime)/(double)sc_clk_tck);

printf("child sys time: %lf\n",

(end_tms.tms_cstime-begin_tms.tms_cstime)/(double)sc_clk_tck);

return0;

}

測試結果如下所示:

ab7653affab982b574eb7acc55df2e04.gif

采用 time 命令, 測試結果如下所示:

ab7653affab982b574eb7acc55df2e04.gif

4 參考網址http://www.01happy.com/linux-process-time/

http://www.01happy.com/c-get-process-time/

linux 查看進程的時鐘時間用戶 CPU 時間和系統 CPU 時間

在 linux 下進行編程時, 可能會涉及度量進程的執行時間 linux 下進程的時間值分三種:

時鐘時間(real time): 指進程從開始執行到結束, 實際執行的時間

用戶 CPU 時間(user CPU time): 指進程中執行用戶指令所用的時間, 也包括子進程

系統 CPU 時間(system CPU time): 指為進程執行內核程序所經歷的時間, 例如調用 read 和 write 內核方法時, 消耗的時間就計入系統 CPU 時間

在 linux 下, 可以使用 time 命令來查看程序執行時這三種時間值的消耗筆者寫了一個測試程序, 來演示這一個過程:#include

intmain(void)

{

inti;

while(i<=10E7){

i++;

}

return1;

}

程序非常簡單了, 就不說明了, 編譯成二進制文件 a.out, 使用 time 命令執行, 在筆者的電腦上輸入如下信息:$ time./a.out

real0m0.349s

user0m0.340s

sys0m0.004s

其中 real 表示時鐘時間, user 表示用戶 CPU 時間, sys 表示系統 CPU 時間 time 命令也可以用于系統的命令, 如 time lstime ps 等等

C 語言獲取時鐘時間用戶 CPU 時間和系統 CPU 時間

C 語言里可以通過 times 函數獲取這三種時間, times 函數說明如下:#include

clock_ttimes(structtms*buf);

參數 tms 的結構如下:structtms{

clock_ttms_utime;/* user time */

clock_ttms_stime;/* system time */

clock_ttms_cutime;

/* user time of children */

clock_ttms_cstime;

/* system time of children */

};

其中時間都是以滴答數 (clock tick) 為單位, 詳細可以用 man 2 times 查看幫助手冊下面的示例用來計算執行系統命令 date 消耗的三種時間值#include

#include

#include

#include

intmain(void)

{

// 獲取滴答數, 在 ubuntu 12.04 下為 100

intclktck=0;

if

((clktck=sysconf(_SC_CLK_TCK))<0){

printf("%s\n","sysconf error");

exit(0);

}

struct

tms? tmsstart,tmsend;

clock_tstart,end;

// 獲取開始時間

if

((start=times(&tmsstart))==-1){

printf("%s\n","times error");

exit(0);

}

// 執行系統函數 date

system("date");

// 獲取結束時間

if

((end=times(&tmsend))==-1){

printf("%s\n","times error");

exit(0);

}

printf("real: %7.2f\n",(end-start)/(double)clktck);

printf("user: %7.2f\n",

(tmsend.tms_utime-tmsstart.tms_utime)/(

double)clktck);

printf("sys:? %7.2f\n",

(tmsend.tms_stime-tmsstart.tms_stime)/(

double)clktck);

printf(

"child user: %7.2f\n"

,

(tmsend.tms_cutime-tmsstart.tms_cutime)/(

double)clktck);

printf(

"child sys:? %7.2f\n"

,

(tmsend.tms_cstime-tmsstart.tms_cstime)/(

double)clktck);

return1;

}

編譯執行上面的程序, 輸出如下:$./a.out

SunDec912:50:39CST2012

real:0.01

user:0.00

sys:0.00

child user:0.00

child sys:0.00

其中 child user 就是執行 date 命令消耗的用戶 CPU 時間, child sys 就是執行 date 命令消耗的系統 CPU 時間這里會發現這兩個值都為 0, 因為滴答數為 100, 只能精確到小數點后面兩位, date 的執行時間非常快, 所以就為 0 了如何精確到小數點后面 3 位呢?

來源: http://www.bubuko.com/infodetail-2506242.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/370213.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/370213.shtml
英文地址,請注明出處:http://en.pswp.cn/news/370213.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Java環境變量的設置

1.計算機->屬性->高級系統設置->環境變量 2.設置JAVA_HOME和path&#xff0c;1.5之后的JDK可以不設置classpath 3.JAVA_HOME的路徑是JDK的安裝路徑 4.在系統變量里面找到path&#xff0c;然后點擊修改&#xff0c;在最后面添加%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin; 5…

merge

merge語句具有按條件獲取要更新或插入到表中的數據行&#xff0c;然后從1個或多個源頭對表進行更新或向表中插入行兩方面的能力。經常用在數據倉庫中移動大量數據。 語法: merge<hint> into<table_name> using<table_view_or_query> on<condition> whe…

可以優化同步嗎?

總覽 有一個常見的誤解&#xff0c;因為JIT很智能&#xff0c;并且可以消除對象的同步&#xff0c;而該對象僅存在于不影響性能的方法中。 比較StringBuffer和StringBuilder的測試 這兩個類基本上做相同的事情&#xff0c;除了一個是同步的&#xff08;StringBuffer&#xff0…

perl exe執行提示缺少文件解決方法

在項目開發中&#xff0c;使用perl語言編譯的exe可執行文件;在項目中使用了XML::LibXML模塊&#xff1b;發現exe在本機電腦執行正常&#xff0c;但在其他同事執行時卻提示缺少libxml2-2.dll等文件。 問題現象&#xff1a; 無法啟動此程序&#xff0c;因為計算機中丟失libxml2-2…

華為搶購助手_華為榮耀20系列手機采用的五項新科技,科普簡介

5月底榮耀20系列在上海發布&#xff0c;榮耀20系列旗艦手機擁有五項榮耀自主研發的新科技&#xff0c;包括LinkTurbo網絡聚合加速、超級NFC、方舟編譯器、人性化YOYO智慧生命體&#xff0c;超級藍牙。下面分別介紹一下這五項新科技。LinkTurbo網絡聚合加速先來科普一下LinkTurb…

Flex彈性布局

1 Flex: 彈性布局 (轉) 任何一個容器都可以指定為 Flex 布局。 1 .box {2  display: flex;3 } 行內元素也可以使用 Flex 布局。 1 .box{2 display: inline-flex;3 } 注意&#xff0c;設為 Flex 布局以后&#xff0c;子元素的 float、 clear 和 vertical-align 屬性將失效…

洛谷P3045 [USACO12FEB]牛券Cow Coupons

P3045 [USACO12FEB]牛券Cow Coupons 71通過248提交題目提供者洛谷OnlineJudge標簽USACO2012云端難度提高/省選-時空限制1s / 128MB提交 討論 題解 最新討論更多討論 86分求救題目描述 Farmer John needs new cows! There are N cows for sale (1 < N < 50,000), and …

python數據挖掘電影評分分析_Pyhon數據分析項目——男女電影評分差異比較

《用Python玩轉數據》數據分析項目一、程序功能基于MovieLens100k數據集中男性女性對電影的評分來判斷男性還是女性電影評分的差異性更大。二、數據來源數據集下載&#xff1a;http://files.grouplens.org/datasets/movielens/ml-100k.zip數據含義&#xff1a;u.data表示100k條…

發掘Apache Camel的力量

最近幾年&#xff0c;ESB軟件越來越受歡迎。 如果大多數人通常知道什么是ESB&#xff0c;那么他們很少會清楚地了解這種體系結構的不同組件的確切作用。 例如&#xff0c;Apache ServiceMix由三個主要組件組成&#xff1a;Apache Karaf&#xff08;OSGI容器&#xff09;&#…

unix/linux系統中文件分為哪些類型?,到底該如何理解 Unix/Linux 的文件系統?看這篇就知道了...

原標題&#xff1a;到底該如何理解 Unix/Linux 的文件系統&#xff1f;看這篇就知道了作者&#xff1a;舠

【Luogu】P1131時態同步(樹形DP)

題目鏈接 甚矣吾衰也&#xff01;這么簡單的DP我都不會了 太恐怖了 樹形DP&#xff0c;從子樹里選出時間最長的來&#xff0c;剩下的調到這個最長時間即可。 #include<cstdio> #include<cctype> #include<algorithm> #include<cstring>using std::max;…

HTML小記

1、頁面內跳轉 當<a>元素用于頁面內的錨點跳轉時&#xff0c;應該先為該頁面設置一些錨點&#xff0c;而定義錨點有兩種辦法&#xff1a; 通過<a>元素的name屬性來定義&#xff0c;如&#xff1a;<a name"anchor-name">name屬性的值就是錨點的名…

python3連接數據庫失敗_python3使用pymysql連接mysql數據庫報Keyerror

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓不好意思Traceback (most recent call last):File "d:\Python\practice2\mydbconn.py", line 5, in conn pymysql.connect(usertestuser, passwdtestpasswd,host192.168.1.3, dbtest,charsetutf8)File "C:\Users\t…

MantisBT 問題分配顯示 姓名

MantisBT 在提交問題的時候&#xff0c;系統默認“分配”給備選賬號&#xff0c;而不是姓名。這樣在使用的時候很不便。能夠通過改動配置文件來改變&#xff0c;找到MantisBT根文件夾下文件config_inc.php&#xff0c;用文本編輯器打開。代碼例如以下&#xff1a; <?php $g…

使用多種MIME類型測試REST

1.概述 本文將重點介紹測試具有多種媒體類型/表示形式的RESTful服務。 這是關于使用Spring和基于Java的配置的Spring Security設置安全的RESTful Web Service的系列文章的第十篇。 REST with Spring系列&#xff1a; 第1部分 – 使用Spring 3.1和基于Java的配置引導Web應用程序…

firewallD卸載Linux,在Ubuntu 18.04/16.04系統上安裝和使用Firewalld的方法

本文介紹Firewalld在Ubuntu 18.04或Ubuntu 16.04發行版上的安裝方法及基本用法。簡介Firewalld是Linux防火墻管理工具&#xff0c;支持IPv4、IPv6、以太網橋和IPSet防火墻設置&#xff0c;它充當Linux內核的netfilter框架的前端&#xff0c;同時Firewalld是RHEL 7系列上的默認防…

JavaWeb學習中的小問題

1. HttpServletRequest和ServletRequest之間的區別&#xff1f; 再看別人項目的時候突然看到一句&#xff1a; ServletRequest request&#xff1b;HttpServletRequest hsRequest (HttpServletRequest) request;// 獲取HttpServletRequest對象瞬間就有一點懵逼 &#xff0c;趕…

python 結構數組_Python數組

數組是一個容器&#xff0c;它可以容納一定數量的項目&#xff0c;這些項目是相同的類型。 大部分數據結構都使用數組來實現它們的算法。 以下是理解數組(Array)概念的重要術語。元素 - 存儲在數組中的每個項目稱為元素。索引 - 數組中元素的每個位置都有一個數字索引&#xff…

廣播 布局文件代碼

<?xml version"1.0" encoding"utf-8"?><RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android" xmlns:app"http://schemas.android.com/apk/res-auto" xmlns:tools"http://schemas.android.com/…

PCGen的垃圾收集分析

介紹 我決定結合我的兩個軟件愛好&#xff0c;并在PCGen上進行一些分析&#xff0c; PCGen是一種流行的基于Java的開放源代碼角色生成器&#xff0c;用于角色扮演游戲。 我用Censum &#xff0c;我們&#xff08; jClarity的&#xff09;新的垃圾收集日志分析工具來進行分析。 …