時(shí)間:2015/6/28來源:IT貓撲網(wǎng)作者:網(wǎng)管聯(lián)盟我要評(píng)論(0)
Linux下time命令可以獲取到一個(gè)程序的執(zhí)行時(shí)間,包括程序的實(shí)際運(yùn)行時(shí)間(real time),以及程序運(yùn)行在用戶態(tài)的時(shí)間(user time)和內(nèi)核態(tài)的時(shí)間(sys time)。
它的使用方法和前面講過的strace類似,在待執(zhí)行的命令前加上time即可。
來看一個(gè)例子程序test.c
#include <stdio.h>
int main()
{
FILE *fp = fopen("/tmp/testfile","w");
int i=0;
for(i=0;i<3;++i)
{
fprintf(fp,"%d\n",i);
}
fclose(fp);
return 0;
}
編譯后用time命令來統(tǒng)計(jì)它的執(zhí)行時(shí)間:
[leconte@localhost test]$ time ./test
real 0m0.020s
user 0m0.000s
sys 0m0.018s
結(jié)果表明,程序?qū)嶋H運(yùn)行時(shí)間0.020s,用戶態(tài)運(yùn)行時(shí)間接近0s,內(nèi)核態(tài)運(yùn)行時(shí)間0.018s。這是因?yàn)槲覀冎饕僮魇鞘褂梦募嚓P(guān)的系統(tǒng)調(diào)用,程序大部分時(shí)間工作在內(nèi)核態(tài)。
需要注意的是,real并不等于user+sys的總和。real代表的是程序從開始到結(jié)束的全部時(shí)間,即使程序不占CPU也統(tǒng)計(jì)時(shí)間。而user+sys是程序占用CPU的總時(shí)間,因此real總是大于或者等于user+sys的。
例如我在上述程序中加上sleep(1):
for(i=0;i<3;++i)
{
sleep(1);
fprintf(fp,"%d\n",i);
}
用time統(tǒng)計(jì)結(jié)果如下:
[leconte@localhost test]$ time ./test
real 0m3.025s
user 0m0.000s
sys 0m0.019s
由于執(zhí)行了三次 sleep(1),real的時(shí)間比剛才多了3s,這3s內(nèi)程序并沒有占用CPU,因此user+sys并沒有變化。
關(guān)鍵詞標(biāo)簽:time命令
相關(guān)閱讀
熱門文章 安裝紅帽子RedHat Linux9.0操作系統(tǒng)教程使用screen管理你的遠(yuǎn)程會(huì)話GNU/Linux安裝vmware如何登錄linux vps圖形界面 Linux遠(yuǎn)程桌面連
人氣排行 Linux下獲取CPUID、硬盤序列號(hào)與MAC地址linux tc實(shí)現(xiàn)ip流量限制dmidecode命令查看內(nèi)存型號(hào)linux下解壓rar文件安裝紅帽子RedHat Linux9.0操作系統(tǒng)教程Ubuntu linux 關(guān)機(jī)、重啟、注銷 命令lcx.exe、nc.exe、sc.exe入侵中的使用方法查看linux服務(wù)器硬盤IO讀寫負(fù)載