linux下对函数运行时间的简单估计

简介: linux下对函数运行时间的简单估计

前言

 性能的要求一定是在慢慢的成长中一点点接触到的,比如50hz的图像,就需要我们在20ms内将数据处理完成,那我们怎么简单估算下我们代码的运行时间呢?

clock_gettime函数

介绍说明

 函数"clock_gettime"是基于Linux C语言的时间函数,他可以用于计算精度和纳秒

函数原型

 extern int clock_gettime (clockid_t __clock_id, struct timespec *__tp) __THROW;

参数

__clock_id : 时钟类型,posix标准定义了下面的四种基本类型,Linux系统有其他的扩充

CLOCK_REALTIME:系统实时时间,随系统实时时间改变而改变,即从UTC1970-1-1 0:0:0开始计时,中间时刻如果系统时间被用户改成其他,则对应的时间相应改变。

CLOCK_MONOTONIC:从系统启动这一刻起开始计时,不受系统时间被用户改变的影响

CLOCK_PROCESS_CPUTIME_ID:本进程到当前代码系统CPU花费的时间。需要注意是不是进程开始到当前代码的时间。

CLOCK_THREAD_CPUTIME_ID:本线程到当前代码系统CPU花费的时间。需要注意是不是线程开始到当前代码的时间。

/* POSIX.1b structure for a time value.  This is like a `struct timeval' but
   has nanoseconds instead of microseconds.  */
struct timespec
{
    __time_t tv_sec;            /* Seconds.  */
    __syscall_s long_t tv_nsec;  /* Nanoseconds.  */
};

头文件

#include <time.h>

 好了,无非就是根据精度获取在目标代码运行前后读取做差值就是了,如果精度不够,可以比如循环运行100次代码,取时间平均值这样,给出ms级和us级的计算方法,先用sleep测试误差

ms级别

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
#include <string.h>
timeval clockGetTime(clockid_t _tclock_id)
{
  struct timespec stTime;
  //该函数的时间精确到纳秒级别
  clock_gettime(_tclock_id, &stTime);
  timeval stRet;
  stRet.tv_sec = stTime.tv_sec;
  stRet.tv_usec = stTime.tv_nsec/1000;
  return stRet; 
}
int main(void)
{
  timeval tmp = {0};
  int timeOffset = 0;
  int timeOffset1 = 0;
    tmp = clockGetTime(CLOCK_MONOTONIC);
  //单位ms
  timeOffset = tmp.tv_sec*1000 + tmp.tv_usec/1000;
  sleep(5);
  /*模拟代码运行时间*/
  memset(&tmp,0,sizeof(tmp));
  tmp = clockGetTime(CLOCK_MONOTONIC);
  timeOffset1 = tmp.tv_sec*1000 + tmp.tv_usec/1000;
    printf("timeOffset:%d\n",(timeOffset1 - timeOffset));
  return 0;
}

us级别

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
#include <string.h>
timeval clockGetTime(clockid_t _tclock_id)
{
  struct timespec stTime;
  //该函数的时间精确到纳秒级别
  clock_gettime(_tclock_id, &stTime);
  timeval stRet;
  stRet.tv_sec = stTime.tv_sec;
  stRet.tv_usec = stTime.tv_nsec/1000;
  return stRet; 
}
int main(void)
{
  timeval tmp = {0};
  int timeOffset = 0;
  int timeOffset1 = 0;
    tmp = clockGetTime(CLOCK_MONOTONIC);
  //单位us
  timeOffset = tmp.tv_sec*1000*1000 + tmp.tv_usec;
  sleep(5);
  /*模拟代码运行时间*/
  memset(&tmp,0,sizeof(tmp));
  tmp = clockGetTime(CLOCK_MONOTONIC);
  timeOffset1 = tmp.tv_sec*1000*1000 + tmp.tv_usec;
    printf("timeOffset:%d\n",(timeOffset1 - timeOffset));
  return 0;
}


相关文章
|
7月前
|
存储 Linux
linux中的目录操作函数
本文详细介绍了Linux系统编程中常用的目录操作函数,包括创建目录、删除目录、读取目录内容、遍历目录树以及获取和修改目录属性。这些函数是进行文件系统操作的基础,通过示例代码展示了其具体用法。希望本文能帮助您更好地理解和应用这些目录操作函数,提高系统编程的效率和能力。
304 26
|
9月前
|
Linux
【Linux】System V信号量详解以及semget()、semctl()和semop()函数讲解
System V信号量的概念及其在Linux中的使用,包括 `semget()`、`semctl()`和 `semop()`函数的具体使用方法。通过实际代码示例,演示了如何创建、初始化和使用信号量进行进程间同步。掌握这些知识,可以有效解决多进程编程中的同步问题,提高程序的可靠性和稳定性。
429 19
|
9月前
|
Linux Android开发 开发者
linux m、mm、mmm函数和make的区别
通过理解和合理使用这些命令,可以更高效地进行项目构建和管理,特别是在复杂的 Android 开发环境中。
401 18
|
9月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
383 13
|
Linux Shell
Linux系统编程:掌握popen函数的使用
记得在使用完 `popen`打开的流后,总是使用 `pclose`来正确关闭它,并回收资源。这种做法符合良好的编程习惯,有助于保持程序的健壮性和稳定性。
514 6
|
Linux Shell
Linux系统编程:掌握popen函数的使用
记得在使用完 `popen`打开的流后,总是使用 `pclose`来正确关闭它,并回收资源。这种做法符合良好的编程习惯,有助于保持程序的健壮性和稳定性。
307 3
在Linux内核中根据函数指针输出函数名称
在Linux内核中根据函数指针输出函数名称
|
Linux PHP
Linux CentOS 宝塔 Suhosin禁用php5.6版本eval函数详细图文教程
【8月更文挑战第27天】本文介绍两种禁用PHP执行的方法:使用`PHP_diseval_extension`禁用和通过`suhosin`禁用。由于`suhosin`不支持PHP8,仅适用于PHP7及以下版本,若服务器安装了PHP5.6,则需对应安装`suhosin-0.9.38`版本。文章提供了详细的安装步骤,并强调了宝塔环境下与普通环境下的PHP路径差异。安装完成后,在`php.ini`中添加`suhosin.so`扩展并设置`executor.disable_eval = on`以禁用执行功能。最后通过测试代码验证是否成功禁用,并重启`php-fpm`服务生效。
302 2
|
Shell Linux C语言
Linux0.11 execve函数(六)
Linux0.11 execve函数(六)
387 1
|
Linux API
Linux源码阅读笔记07-进程管理4大常用API函数
Linux源码阅读笔记07-进程管理4大常用API函数