博客
关于我
linux获取进程执行时间方法示例
阅读量:225 次
发布时间:2019-03-01

本文共 2121 字,大约阅读时间需要 7 分钟。

Linux 获取进程执行时间的方法

在 Linux 环境中,获取进程的执行时间有两种主要方法。第一种是使用 time 命令,第二种是通过程序内部记录时间。以下将详细介绍这两种方法,并提供一个测试示例来展示实际效果。

前言

测试一个程序的执行时间通常包括用户 CPU 时间、系统 CPU 时间以及总计时钟时间。在早期,开发者通常在 main 函数中使用 time 函数来测量程序的执行时间。然而,这种方法只能粗略地估算程序的执行时间,无法精确获取用户和系统 CPU 时间。通过阅读《APUE》(Advanced Programming Unix Environment)等书籍,我了解到可以使用更精确的方法来测试程序的各项时间参数。

获取方法

方法一:使用 time 命令

time 命令是一个强大的工具,可以用来测量程序的执行时间。运行以下命令可以获取某个进程的详细执行时间信息:

time your_program

执行结果会显示以下信息:

  • 实际执行时间(real time):包括用户和系统 CPU 时间总和。
  • 用户 CPU 时间(user time):仅包括用户模式下的 CPU 时间。
  • 系统 CPU 时间(system time):仅包括内核模式下的 CPU 时间。

例如,假设运行以下命令:

time echo "Hello, World!"

输出可能如下:

Hello, World! 0.00s 0.00s 0.00s 0.00s + 0.003s 1000.000us 3000us

从输出中可以看到,real time 为 0 秒,user timesystem time 均为 0 秒。

方法二:程序内部记录时间

第二种方法是通过在程序内部记录时间。这种方法可以更精确地获取用户和系统 CPU 时间。具体步骤如下:

  • 使用 sysconf 函数获取系统时钟滴答次数。这个值与 times 函数返回的时钟时间有关。

  • 使用 times 函数获取当前进程的时间信息。times 函数返回一个 tms 结构体,包含以下字段:

    • tms_utime:用户 CPU 时间。
    • tms_stime:系统 CPU 时间。
    • tms_cutime:用户模式下运行的子进程 CPU 时间。
    • tms_cstime:系统模式下运行的子进程 CPU 时间。
  • 计算时间差,将时钟滴答次数除以 sysconf(_SC_CLK_TCK) 得到实际时间。

  • 以下是一个示例程序:

    #include 
    #include
    #include
    #include
    #define BUFFER_SIZE 4 * 1024int main() { int sc_clk_tck; sc_clk_tck = sysconf(_SC_CLK_TCK); struct tms begin_tms, end_tms; clock_t begin, 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); return 0;}

    测试结果

    运行上述程序,您将看到以下输出:

    real time: 2.000000user time: 2.000000sys time: 0.000000child user time: 0.000000child sys time: 0.000000

    从输出中可以看出,用户和系统 CPU 时间分别为 2 秒和 0 秒,表示该程序在运行 2 秒后完成,主要消耗的时间来自用户模式。

    总结

    通过以上两种方法,可以精确地测量进程的执行时间。使用 time 命令简单易于操作,而在程序内部记录时间则提供了更高的精度,尤其是在需要详细分析 CPU 使用情况时。

    转载地址:http://rpyv.baihongyu.com/

    你可能感兴趣的文章
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    NFS共享文件系统搭建
    查看>>
    ng 指令的自定义、使用
    查看>>
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>
    Nginx Location配置总结
    查看>>
    Nginx 动静分离与负载均衡的实现
    查看>>
    Nginx 反向代理解决跨域问题
    查看>>
    Nginx 反向代理配置去除前缀
    查看>>
    nginx 后端获取真实ip
    查看>>
    Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
    查看>>
    nginx 常用配置记录
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>