嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间

简介: 在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。

嵌入式Linux系统编程 — 使用times和clock函数获取进程时间

一、前言

在嵌入式Linux系统编程中,准确获取和测量进程的执行时间对于性能分析和优化至关重要。Linux提供了多种方式来获取进程的时间信息,其中 timesclock函数是最常用的两种方法。本文将详细介绍这两个函数的用法及其在嵌入式系统中的应用。

二、times函数

1. 概述

times函数用于获取当前进程以及其子进程的用户时间和系统时间。该函数在 unistd.h头文件中声明,返回一个 clock_t类型的值,表示从系统启动到调用此函数时的时间,单位为时钟滴答(clock ticks)。

2. 函数定义

#include <unistd.h>
#include <sys/times.h>

clock_t times(struct tms *buf);
​
  • 参数

    • buf:指向 tms结构体的指针,用于存储当前进程和子进程的时间信息。
  • 返回值

    • 成功时,返回从系统启动到当前时间的时钟滴答数。
    • 失败时,返回(clock_t)-1,并设置 errno

3. tms结构体

tms结构体包含以下成员:

struct tms {
    clock_t tms_utime;  // 用户时间
    clock_t tms_stime;  // 系统时间
    clock_t tms_cutime; // 子进程用户时间
    clock_t tms_cstime; // 子进程系统时间
};
​

4. 示例代码

以下是一个使用 times函数获取进程时间的示例:

#include <stdio.h>
#include <unistd.h>
#include <sys/times.h>
#include <time.h>

int main() {
    struct tms start_time, end_time;
    clock_t start, end;
    long ticks_per_second = sysconf(_SC_CLK_TCK);

    // 获取开始时间
    start = times(&start_time);

    // 模拟工作负载
    for (volatile long i = 0; i < 1000000000; i++);

    // 获取结束时间
    end = times(&end_time);

    // 计算并显示时间差
    printf("User time: %f seconds\n", (double)(end_time.tms_utime - start_time.tms_utime) / ticks_per_second);
    printf("System time: %f seconds\n", (double)(end_time.tms_stime - start_time.tms_stime) / ticks_per_second);
    printf("Elapsed time: %f seconds\n", (double)(end - start) / ticks_per_second);

    return 0;
}
​

三、clock函数

1. 概述

clock函数用于获取当前进程从启动到调用此函数时所使用的处理器时间。该函数在 time.h头文件中声明,返回一个 clock_t类型的值,表示处理器时间,单位为时钟滴答(clock ticks)。

2. 函数定义

#include <time.h>

clock_t clock(void);
​
  • 返回值

    • 成功时,返回从进程启动到当前时间的处理器时间(时钟滴答数)。
    • 失败时,返回(clock_t)-1,并设置 errno

3. 示例代码

以下是一个使用 clock函数获取进程时间的示例:

#include <stdio.h>
#include <time.h>

int main() {
    clock_t start, end;
    double cpu_time_used;

    // 获取开始时间
    start = clock();

    // 模拟工作负载
    for (volatile long i = 0; i < 1000000000; i++);

    // 获取结束时间
    end = clock();

    // 计算并显示时间差
    cpu_time_used = ((double) (end - start)) / CLOCKS_PER_SEC;
    printf("CPU time used: %f seconds\n", cpu_time_used);

    return 0;
}
​

四、times与clock的对比

1. 用途

  • times:适用于需要获取进程和其子进程详细时间信息的场景。
  • clock:适用于需要快速获取进程CPU时间的场景。

2. 精度

  • times:提供更详细的时间信息,包括用户时间和系统时间,但需要考虑时钟滴答数。
  • clock:返回处理器时间,单位为时钟滴答,使用更简单。

3. 开销

  • times:开销较大,因为需要获取多个时间值。
  • clock:开销较小,获取单一的处理器时间。

五、应用场景

  • 性能分析:在嵌入式系统中,使用 times函数可以详细分析每个进程和子进程的CPU时间消耗,帮助优化系统性能。
  • 资源管理:使用 clock函数可以快速监控进程的CPU使用情况,帮助开发者管理系统资源,避免资源耗尽。

六、总结

在嵌入式Linux系统编程中,timesclock函数是获取进程时间的两个重要工具。times函数提供了更详细的进程和子进程时间信息,而 clock函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。

目录
相关文章
|
4月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
354 3
Linux系统禁用swap
|
4月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
743 3
|
5月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
5月前
|
存储 Ubuntu Linux
「正点原子Linux连载」第二章Ubuntu系统入门
在图2.8.2.4中,我们使用命令umount卸载了U盘,卸载以后当我们再去访问文件夹/mnt/tmp的时候发现里面没有任何文件了,说明我们卸载成功了。
|
3月前
|
监控 关系型数据库 MySQL
在CentOS系统中,如何统计哪个进程打开了文件描述符?
利用上述方法,你可以有效地监控和统计CentOS系统中的进程打开的文件描述符数量,以帮助排查错误或优化系统配置。通过组合使用各种工具和命令,可以获得对系统状态和行为的深入了解,进而做出相应的调整和
184 5
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
470 0
Linux系统初始化脚本
|
5月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
326 18
|
4月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
403 1
|
4月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
1094 1
|
5月前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
1733 10