墙上时钟时间 ,用户cpu时间 ,系统cpu时间

1、 墙上时钟时间 ,用户cpu时间 ,系统cpu时间定义与联系html

时钟时间(墙上时钟时间wall clock time):从进程从开始运行到结束,时钟走过的时间,这其中包含了进程在阻塞和等待状态的时间。ubuntu

用户CPU时间:就是用户的进程得到了CPU资源之后,在用户态执行的时间。
系统CPU时间:用户进程得到了CPU资源之后,在内核态的执行时间。

   进程的三种状态为阻塞、就绪、运行。

   时钟时间 = 阻塞时间 + 就绪时间 +运行时间
   用户CPU时间 = 运行状态下用户空间的时间
   系统CPU时间 =  运行状态下系统空间的时间。

测试

   用户CPU时间+系统CPU时间=运行时间。ui

注意:
其中,用户CPU时间和系统CPU时间之和为CPU时间,即命令占用CPU执行的时间总和。实际时间要大于CPU时间,由于Linux是多任务操做系统,每每在执行一条命令时,系统还要处理其它任务。
另外一个须要注意的问题是即便每次执行相同命令,但所花费的时间也是不同,其花费时间是与系统运行相关的。spa

 

 

 

在多核处理器机器上,若进程含有多个线程或经过fork调用建立子进程,则实际时间(墙上时钟时间)可能小于CPU总时间——由于不一样线程或进程可并行执行,但其时间会计入主进程的CPU总时间。若程序在某段时间处于等待状态而并未执行,则实际时间可能大于CPU总时间。其数值关系总结以下:操作系统

  • Real < CPU,代表进程为计算密集型(CPU bound),利用多核处理器的并行执行优点;
  • Real ≈ CPU,代表进程为计算密集型(CPU bound),未并行执行;
  • Real > CPU,代表进程为I/O密集型(I/O bound),多核并行执行优点并不明显。

在单核处理器上,Real时间和CPU时间之差,即Real- (User + Sys)是全部延迟程序执行的因素的总和。可估算程序运行期间的CPU利用率为CpuUsage = (User + Sys)/ Real * 100(%)。.net

在SMP(对称多处理系统)上,该差值近似为Real* ProcessorNum - (User + Sys)。这些因素包括:线程

  • 调入程序文本和数据的I/O操做;
  • 获取程序实际使用内存的I/O操做;
  • 由其它程序消耗的CPU用时;
  • 由操做系统消耗的CPU用时。

 

2、实例unix

 linshuqiang@ubuntu:~/temp$ time  ./test  
    sdga  
    s   d   g   a     
     //上面是测试test程序的   
    real    0m4.019s                     //时钟时间  
    user    0m0.004s           //用户CPU时间  
    sys 0m0.000s                   //系统CPU时间  

 


3、参考文献code

 

http://os.51cto.com/art/201407/445853.htm (说得很详细,值得看一下)

http://blog.chinaunix.net/uid-27629574-id-3880991.html

http://blog.csdn.net/fjt19900921/article/details/8301230

相关文章
相关标签/搜索