Linux C++程序进行性能分析工具gprof使用入门

本文介绍了Linux下C++程序性能分析工具gprof的使用,包括其基本原理、使用步骤和输出解读。gprof通过在编译时添加-pg选项收集函数调用信息,形成调用关系图和性能数据,帮助开发者定位耗时点。通过gprof,可以看到每个函数的调用次数、执行时间和相互调用关系,但要注意gprof对多线程支持不佳且仅分析用户时间。
摘要由CSDN通过智能技术生成

性能分析工具

软件的性能是软件质量的重要考察点,不论是在线服务程序还是离线程序,甚至是终端应用,性能都是用户体验的关键。这里说的性能重大的范畴来讲包括了性能和稳定性两个方面,我们在做软件测试的时候也是要重点测试版本的性能表现和稳定性的。对于软件测试过程中发现的性能问题,如何定位有很多的方法。基本的方法可能是开发者对代码进行review,或者是使用一些工具对代码进行性能分析。常见的性能分析tuning工具有哪些呢?下面两篇文章做了详细的总结:

在我工作中主要是关于Linux C++程序代码的性能分析,gprof是可用于Linux C++代码性能profiling的工具之一,本文主要讲讲我对gprof的学习和使用过程。


Gprof的基本原理

gprof能够让你知道你的代码哪些地方是比较耗时的,哪些函数是被调用次数很多的,并且能够让你一目了然的看到函数与函数之间的调用关系。gprof是gcc/g++编译器支持的一种性能诊断工具。只要在编译时加上-pg选项,编译器就会在编译程序时在每个函数的开头加一个mcount函数调用,在每一个函数调用之前都会先调用这个mcount函数,在mcount中会保存函数的调用关系图和函数的调用时间和被调次数等信息。最终在程序退出时保存在gmon.out文件中,需要注意的是程序必须是正常退出或者通过exit调用退出,因为只要在exit()被调用时才会触发程序写gmon.out文件。

那么,gprof的使用方法主要以下三步:

  • 会用-pg参数编译程序
  • 运行程序,并正常退出
  • 查看gmon.out文件

Gprof使用实例

[cpp]  view plain  copy
 print ?
  1. #include<iostream>  
  2. using namespace std;  
  3.   
  4. int add(int a, int b)  
  5. {  
  6.         return a+b;  
  7. }  
  8.   
  9. int sub(int a, int b)  
  10. {  
  11.         return a-b;  
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值