ldd gperftool 用法

2024-06-02 11:18
文章标签 用法 ldd gperftool

本文主要是介绍ldd gperftool 用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


1.ldd 用来显示进程所依赖的动态库路径

[root@iZ94xjteonrZ C++]# ldd test
        linux-vdso.so.1 =>  (0x00007fff8cb08000)
        libprofiler.so.0 => /usr/local/lib/libprofiler.so.0 (0x00007fb1f0d6a000)
        libunwind.so.8 => not found
        libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fb1f0b4c000)
        libc.so.6 => /lib64/libc.so.6 (0x00007fb1f07b9000)
        libunwind.so.7 => not found
        libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00007fb1f04b2000)
        libm.so.6 => /lib64/libm.so.6 (0x00007fb1f022e000)
        libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007fb1f0018000)
        /lib64/ld-linux-x86-64.so.2 (0x00007fb1f0f83000)
[root@iZ94xjteonrZ C++]# 


export LD_LIBRARY_PATH 的使用 用来设置环境变量  设置共享库的搜索位置


2.

1. 下载libunwind (wget http://download.savannah.gnu.org/releases/libunwind/libunwind-1.1.tar.gz)

    mkdir ../libunwind

    ./configure prefix=/home/tools/libunwind

    make  && make install


2. 下载 gperftools (wget http://code.google.com/p/gperftools/downloads/list/gperftools-2.0.tar.gz

    mkdir ../gperftools 

   ./configure prefix=/home/tools/gperftools --enable-frame-pointers

    make  && make install

 


 

3. export LD_LIBRARY_PATH=/home/tools/gperftools/lib

    export PATH=$PATH:/home/tools/gperftools/bin

 

4. mkdir ../test && cd ../test

    vi test.cpp

#include <google/profiler.h>
#include <iostream>
using namespace std;
void test1() 

{
    int i = 0;
    while (i < 1000) 

     {
        i++;
    }  
}

void test2() 
{

    int i = 0;
    while (i < 2000)  

   {
        i++;
    }  
}


void test3() 

 {
    for (int i = 0; i < 100000; ++i) 
    {
        test1();
        test2();
    }  
}


int main()

 {
    ProfilerStart("test.prof"); // test.prof is the name of profile file
     test3();
    printf("Finish!");
    ProfilerStop(); 
    return 0;
}

 

5. 编译

   g++ -o test test.cpp -I /home/tools/gperftools/include -I /home/tools/libunwind/include -L/home/tools/gperftools/lib/ -lprofiler  -L/home/tools/libunwind/lib/ -lunwind

 

6. ./test

生成test.prof文件

 

7. pprof --text test test.prof

输出:

 Using local file test.
Using local file test.prof.
Total: 100 samples
      59  59.0%  59.0%       59  59.0% test2
      40  40.0%  99.0%       40  40.0% test1
       1   1.0% 100.0%        1   1.0% test3

官方文档:http://code.google.com/p/google-perftools/wiki/GooglePerformanceTools


分析输出

pprof脚本用于分析profile文件并输出结果,包括文本和图形两种输出风格。

例如:demo是目标程序,my.prof是profile文件

生成文本风格结果:pprof --text ./demo my.prof > profile.txt

生成图形风格结果:pprof --pdf ./demo my.prof > profile.pdf

 

对于一个函数的CPU使用时间分析,分为两个部分:

1.整个函数消耗的CPU时间,包括函数内部其他函数调用所消耗的CPU时间

2.不包含内部其他函数调用所消耗的CPU时间(内联函数除外)

关于文本风格输出结果
序号 说明
1 分析样本数量(不包含其他函数调用)
2 分析样本百分比(不包含其他函数调用)
3 目前为止的分析样本百分比(不包含其他函数调用)
4 分析样本数量(包含其他函数调用)
5 分析样本百分比(包含其他函数调用)
6 函数名

 

关于图形风格输出结果

1.节点

每个节点代表一个函数,节点数据格式:

Class Name
Method Name
local (percentage)
of cumulative (percentage)

local时间是函数直接执行的指令所消耗的CPU时间(包括内联函数);性能分析通过抽样方法完成,默认是1秒100个样本,一个样本是10毫秒,即时间单位是10毫秒;

cumulative时间是local时间与其他函数调用的总和;

如果cumulative时间与local时间相同,则不打印cumulative时间项。

2.有向边

调用者指向被调用者,有向边上的时间表示被调用者所消耗的CPU时间

 

示例

代码如下,可以看出,CPU消耗集中在func1()和func2()两个函数,func2()消耗时间约为func1()的两倍。

复制代码
#include <google/profiler.h>
#include <iostream>
using namespace std;
void func1() {int i = 0;while (i < 100000) {++i;}  
}
void func2() {int i = 0;while (i < 200000) {++i;}  
}
void func3() {for (int i = 0; i < 1000; ++i) {func1();func2();}  
}
int main(){ProfilerStart("my.prof"); // 指定所生成的profile文件名
    func3();ProfilerStop(); // 结束profilingreturn 0;
}
复制代码

 

然后编译链接运行,使用pprof生成分析结果

g++ -o demo demo.cpp -lprofiler -lunwind
pprof --text ./demo my.prof > output.txt
pprof --pdf ./demo my.prof > output.pdf

查看分析结果,程序是122个时间样本,其中,func1()是40个时间样本,约为400毫秒;func2()是82个时间样本,约为820毫秒。

Total: 122 samples
       82  67.2%  67.2%       82  67.2% func2
       40  32.8% 100.0%       40  32.8% func1
        0   0.0% 100.0%      122 100.0% __libc_start_main
        0   0.0% 100.0%      122 100.0% _start
        0   0.0% 100.0%      122 100.0% func3
        0   0.0% 100.0%      122 100.0% main

 

 


这篇关于ldd gperftool 用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023812

相关文章

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

JavaScript Array.from及其相关用法详解(示例演示)

《JavaScriptArray.from及其相关用法详解(示例演示)》Array.from方法是ES6引入的一个静态方法,用于从类数组对象或可迭代对象创建一个新的数组实例,本文将详细介绍Array... 目录一、Array.from 方法概述1. 方法介绍2. 示例演示二、结合实际场景的使用1. 初始化二

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

关于@RequestParam的主要用法详解

《关于@RequestParam的主要用法详解》:本文主要介绍关于@RequestParam的主要用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 基本用法2. 默认值3. 可选参数4. 绑定到对象5. 绑定到集合或数组6. 绑定到 Map7. 处理复杂类

SQL中的CASE WHEN用法小结

《SQL中的CASEWHEN用法小结》文章详细介绍了SQL中的CASEWHEN函数及其用法,包括简单CASEWHEN和CASEWHEN条件表达式两种形式,并通过多个实际场景展示了如何使用CASEWH... 目录一、简单CASE WHEN函数:二、CASE WHEN条件表达式函数三、常用场景场景1:不同状态展

Linux find 命令完全指南及核心用法

《Linuxfind命令完全指南及核心用法》find是Linux系统最强大的文件搜索工具,支持嵌套遍历、条件筛选、执行动作,下面给大家介绍Linuxfind命令完全指南,感兴趣的朋友一起看看吧... 目录一、基础搜索模式1. 按文件名搜索(精确/模糊匹配)2. 排除指定目录/文件二、根据文件类型筛选三、时间

Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)

《Java导入、导出excel用法步骤保姆级教程(附封装好的工具类)》:本文主要介绍Java导入、导出excel的相关资料,讲解了使用Java和ApachePOI库将数据导出为Excel文件,包括... 目录前言一、引入Apache POI依赖二、用法&步骤2.1 创建Excel的元素2.3 样式和字体2.

kotlin中的行为组件及高级用法

《kotlin中的行为组件及高级用法》Jetpack中的四大行为组件:WorkManager、DataBinding、Coroutines和Lifecycle,分别解决了后台任务调度、数据驱动UI、异... 目录WorkManager工作原理最佳实践Data Binding工作原理进阶技巧Coroutine