zoukankan      html  css  js  c++  java
  • UNIX基础知识之时间值

    本篇博文内容摘自《UNIX环境高级编程》(第二版),仅作个人学习记录所用。关于本书可参考:http://www.apuebook.com/  

      长期以来,UNIX系统一直使用两种不同的时间值:

      (1)日历时间

      该值是自1970年1月1日00:00:00以来国际标准时间(UTC)所经过的秒数累计值(早期的手册称UTC为格林尼治标准时间)。这些时间值用于记录文件最近一次的修改时间等。

      系统基本数据类型time_t用于保存这种时间值。

      (2)进程时间

      这也被称为CPU时间,用以度量进程使用的中央处理机资源。进程时间以时钟滴答计算,历史上曾经去每秒钟为50、60或100个滴答。

      系统基本数据类型clock_t用于保存这种时间值。可以使用sysconf函数得到每秒时钟滴答数。

      当度量一个进程的执行时间时,UNIX系统使用三个进程时间值:

      (1)时钟时间。

      (2)用户CPU时间。

      (3)系统CPU时间。

      时钟时间又称为墙上时钟时间(wall clock time)。它是进程运行的时间总量,其值与系统中同时运行的进程数有关。

      用户CPU时间是执行用户指令所用的时间。系统CPU时间是为该进程执行内核程序所经历的时间。例如,每当一个进程执行一个系统服务时,例如read或write,则在内核中执行该服务所花费的时间就计入该进程的系统CPU时间。用户CPU时间和系统CPU时间之和常被称为CPU时间。

      此处插入参考:http://bbs.csdn.net/topics/320059058

      用户CPU是程序处在用户态的时间,系统CPU的程序处于内核态的时间。
          时钟时间>=用户+系统,是程序实际占用的CPU时间。
          一般情况下real时间是从程序运行到程序结束所用的真实时间,因为运行过程中会被暂时挂起(因为还要运行别的进程),所以real>user+sys。也有real < user+sys的情况
          时钟时间不是两者之和。

      其实 时钟时间与他们并没有什么直接的关系。下面是一些定义
          时钟时间:就是一个进程从开始运行到结束运行后,你的时钟走过了多少时间,这其中包含了进程在阻塞和等待状态的时间。
          用户CPU时间:就是用户的进程获得了CPU资源以后,在用户态执行的时间。
          系统CPU时间:用户进程获得了CPU资源以后,在内核态的执行时间。
          进程的三种状态为阻塞、就绪、运行。
          时钟时间 = 阻塞时间 + 就绪时间 + 运行时间
          用户CPU时间 = 运行状态下的用户空间时间
          系统CPU时间 = 运行状态下系统空间的时间。
          用户CPU时间+系统CPU时间=运行时间(CPU时间)。

      要取得任一进程的时钟时间、用户时间和系统时间是很容易的——只要执行命令time(1),其参数是要度量其执行时间的命令。例如:

    [root@localhost unix_env_advance_prog]# time ls
    apue.h    prog1-1    prog1-2.c  prog1-4    prog1-5.c  prog1-7    prog1-8.c
    error.c   prog1-1.c  prog1-3    prog1-4.c  prog1-6    prog1-7.c
    Makefile  prog1-2    prog1-3.c  prog1-5    prog1-6.c  prog1-8
    
    real    0m0.007s
    user    0m0.000s
    sys     0m0.007s
  • 相关阅读:
    jsp 页面获取当前路径
    html5 页面音频
    微信关于网页授权access_token和普通access_token的区别
    Texlive source
    vscode 快捷键
    vscode setting
    vscode extension 插件管理
    what
    linux manual
    java tool type
  • 原文地址:https://www.cnblogs.com/nufangrensheng/p/3495526.html
Copyright © 2011-2022 走看看