C++ 运行状态分析工具

本文介绍如何利用Valgrind的Callgrind工具记录并分析C++程序中各函数的运行时间开销,通过KCachegrind工具可视化数据,帮助开发者识别并优化性能瓶颈。例如,通过分析发现strtol函数耗时较多,建议避免使用atoi、atol等函数来提升程序效率。
在运行c++程序,需要记录每个函数的运行时间开销,传统采用clock记录比较麻烦。发现一个比较好的工具:

http://valgrind.org/docs/manual/cl-manual.html, 编译好程序, 可以使用如下命令:

valgrind --tool=callgrind [callgrindoptions] your-program [program options] 跑程序,然后采用KCachegrind(http://kcachegrind.sourceforge.net/html/Home.html) 工具视觉化具体参数。

具体界面说明参见:

http://baptiste-wicht.com/posts/2011/09/profile-c-application-with-callgrind-kcachegrind.html


该工具的好处是可以一目了然看出那个函数的开销是比较多,进一步进行时间优化。比如我跑的一个程序的strtol函数开销大,通过其他方式可以避免使用atoi,atol等函数。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值