如何统计程序或函数调用时间

news/2024/11/21 1:35:21/
  1. time()

1、clock() 函数,返回从 开启这个程序进程 到 程序中调用clock()函数 时之间的CPU时钟计时单元数,返回单位是毫秒,可以用常量CLOCKS_PER_SEC, 这个常量表示每一秒有多少个时钟计时单元。

2、time(&temp)函数,返回从CUT(Coordinated Universal Time)时间1970年1月1日00:00:00到当前时刻的秒数,返回单位是秒。

  1. clock()

  1. gprof

1)给GNU Tools 传递PG选项,编译器和连接器都需要加上-pg 选项

gcc -g -pg .............

2)执行程序(注意:只有在程序正常终止的时候,才会生成统计文件。也就是说,程序必须是从exit或者return终止的。)

程序执行结束后,会生成gmon.out 统计文件,这个就是profiler data file。

3)分析生成结果

gprof [Options] <可执行文件>

使用gprof来分析gmon.out文件时,需要把它和产生它的应用程序关联起来:

gprof <program> gmon.out -p 得到每个函数占用的执行时间

gprof <program> gmon.out -q 得到call graph,包含了每个函数的调用关系,调用次数,执行时间等信息。

gprof <program> gmon.out -A 得到 一个带注释的“源代码清单”,它会注释源码,指出每个函数的执行次数。这需要在编译的时候增加 -g选项。


http://www.ppmy.cn/news/34754.html

相关文章

SpringBoot 使用Druid实现数据库连接池并结合AOP实现多数据源

SpringBoot 使用Druid实现数据库连接池并结合AOP实现多数据源 一. 配置Druid二. 实现多数据源三. 添加注解四. 业务代码五. 测试六. 总结Spring Boot是一个快速开发Spring应用程序的框架,而Druid是一个高性能的数据库连接池,可以提高数据库访问的效率。在Spring Boot中使用Dr…

邪恶的想法冒出,立马启动python实现美女通通下

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! 完整源码、python资料: 点击此处跳转文末名片获取 当我在首页刷到这些的时候~ 我的心里逐渐浮现一个邪念&#xff1a;我把这些小姐姐全都采集&#xff0c;可以嘛&#xff1f; 答案当然是可以的~毕竟就我这技术&#xff0c…

短链接是怎么设计的?带你入门

文章目录前言一、短链1、原理1.1 短链生成原理1.2 短链跳转原理&#xff1a;2、设计&#xff1a;2.1 短链需求2.2 考虑的问题&#xff1f;二、实践案例1、设计表&#xff1a;2、生成短链&#xff1a;前言 说到 URL 你肯定不陌生&#xff0c;浏览器输入一段 URL&#xff0c;立马…

J 砍竹子

砍竹子 【问题描述】 这天&#xff0c;小明在砍竹子&#xff0c;他面前有 n 棵竹子排成一排&#xff0c;一开始第 i 棵竹子的高度为 hi . 他觉得一棵一棵砍太慢了&#xff0c;决定使用魔法来砍竹子。魔法可以对连续的一段相同高度的竹子使用&#xff0c;假设这一段竹子的高度…

MySQL 常见的面试题及其答案

目录 1、什么是 MySQL&#xff1f;它的特点是什么&#xff1f; 2、什么是SQL&#xff1f; 3、什么是关系型数据库&#xff1f; 4、什么是主键&#xff1f; 5、什么是外键&#xff1f; 6、什么是索引&#xff1f; 7、什么是存储引擎&#xff1f; 8、什么是事务&#xff…

ChatGPT来了你慌了吗?

文章目录一、ChatGPT是什么&#xff1f;一、ChatGPT到底多强大&#xff1f;三、各平台集成了ChatGPT插件&#xff1a;四、ChatGPT能否取代程序员&#xff1f;一、ChatGPT是什么&#xff1f; ChatGPT&#xff08;全名&#xff1a;Chat Generative Pre-trained Transformer&…

华为OD机试题【IPv4 地址转换成整数】用 Java 解 | 含解题说明

华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南华为od机试,独家整理 已参加机试人员的实战技巧华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典本篇题目:IPv4 地址转换成整数 题目 存在…

python编程:使用pyecharts绘制拟合曲线图

pyecharts库是python下实现的echarts图表绘制库&#xff0c;接下来&#xff0c;我们使用pyecharts来绘制一条曲线&#xff0c;来体验一下pyecharts的基本使用效果。 1、首先&#xff0c;我们要安装下pyecharts库&#xff0c;在pycharm终端输入安装命令&#xff1a; pip install…