zoukankan      html  css  js  c++  java
  • 使用Gnu gprof进行Linux平台下的程序分析

    http://www.pcdog.com/edu/linux/18/10/u231314_1.html
    http://www.pcdog.com/edu/linux/18/10/u231314_2.html
    http://www.pcdog.com/edu/linux/18/10/u231314_3.html


    1. Compile source .c code for analysis, Create executable file:
            >> gcc -pg test.c -o test 

    2. Launch executable file, Create gmon.out
            >> ./test

    3. Use gmon.out to analysis:
            >>  gprof -b test gmon.out | less
        or: >>  gprof -b test gmon.out | more

    4. 
        
         

    常用的Gprof 命令选项解释:
     
    -b不再输出统计图表中每个字段的详细描述。

    -p 只输出函数的调用图(Call graph 的那部分信息)。

    -q 只输出函数的时间消耗列表。

    -E Name不再输出函数Name 及其子函数的调用图,此标志类似于 -e 标志,但它在总时间和百分比时间的计算中排除了由函数Name 及其子函数所用的时间。

    -e Name 不再输出函数Name 及其子函数的调用图(除非它们有未被限制的其它父函数)。可以给定多个 -e 标志。一个 -e 标志只能指定一个函数。

    -F Name 输出函数Name 及其子函数的调用图,它类似于 -f 标志,但它在总时间和百分比时间计算中仅使用所打印的例程的时间。可以指定多个 -F 标志。一个 -F 标志只能指定一个函数。-F 标志覆盖 -E 标志。

    -f Name输出函数Name 及其子函数的调用图。可以指定多个 -f 标志。一个 -f 标志只能指定一个函数。

    -z 显示使用次数为零的例程(按照调用计数和累积时间计算)。

    English Reference:http://www.cs.utah.edu/dept/old/texinfo/as/gprof.html#SEC4


    --------附: vi使用方法:---------


      vi 的三种命令模式  


    Command(命令)模式,用于输入命令
      Insert(插入)模式,用于插入文本
      Visual(可视)模式,用于视化的的高亮并选定正文
      光标移动  
      当我们按ESC进入Command模式后,我们可以用下面的一些键位来移动光标;
      j 向下移动一行
      k 向上移动一行
      h 向左移动一个字符
      l 向右移动一个字符
      ctrl+b 向上移动一屏
      ctrl+f 向下移动一屏
      向上箭头 向上移动
      向下箭头 向下移动
      向左箭头 向左移动
      向右箭头 向右移动
      我们编辑一个文件时,对于 j、k、l和h键,还能在这些动作命令的前面加上数字,比如 3j,表示向下移动3行。
      /# +Enter #为查找的内容 
      插入模式(文本的插入)
      
      i 在光标之前插入
      a 在光标之后插入
      I 在光标所在行的行首插入
      A 在光标所在行的行末插入
      o 在光标所在的行的下面插入一行
      O 在光标所在的行的上面插入一行
      s 用输入的文本替换光标所在字符
      S 用输入的文本替换光标所在行 
      文本内容的删除操作;
      
      x 一个字符
      #x 删除几个字符,#表示数字,比如3x
      dw 删除一个单词
      #dw 删除几个单词,#用数字表示,比如3dw表示删除三个单词
      dd 删除一行;
      #dd 删除多个行,#代表数字,比如3dd 表示删除光标行及光标的下两行
      d$ 删除光标到行尾的内容
      J 清除光标所处的行与下一行之间的换行,行尾没有空格的话会自动添加一个空格。
      #J 表示合并#(数字)行。
      退出保存;
      在命令模式下按 shift+: 文本底端出现冒号
      :w 保存;
      :w filename 另存为filename;
      :wq! 保存退出;
      :wq! filename 注:以filename为文件名保存后退出;
      :q! 不保存退出;
      :x 应该是保存并退出 ,功能和:wq!相同
      撤销操作
      u命令取消最近一次的操作,可以使用多次来恢复原有的操作[1]
      U取消所有操作
      Ctrl+R可以恢复对使用u命令的操作
      复制操作
      yy命令复制当前整行的内容到vi缓冲区
      yw复制当前光标所在位置到单词尾字符的内容到vi缓存区,相当于复制一个单词
      y$复制光标所在位置到行尾内容到缓存区
      y^复制光标所在位置到行首内容到缓存区
      #yy例如:5yy就是复制5行
      #yw例如:2yw就是复制两个单词
      如果要复制第m行到第n行之间的内容,可以在末行模式中输入m,ny例如:3,5y复制第三行到第五行内容到缓存区。
      查找和替换
      vi的查找和替换功能主要在末行模式完成:
      至上而下的查找
      / 要查找的字符串,其中/代表从光标所在位置起开始查找,例如:/ work
      至下而上的查找
      ?要查找的字符串 例如:? work
      替换
      :s/old/new用new替换行中首次出现的old
      : s/old/new/g 用new替换行中所有出现的old
      :#,# s/old/new/g用new替换从第#行到第#行中出现的old
      :% s/old/new/g用new替换整篇中出现的old
      如果替换的范围较大时,在所有的命令尾加一个c命令,强制每个替换需要用户进行确认,例如:s/old/new/c 或s/old/new/gc
      恢复文件  
     vi在编辑某一个文件时,会生成一个临时文件,这个文件以 . 开头并以 .swp结尾。正常退出该文件自动删除,如果意外退出例如忽然断电,该文件不会删除,我们在下次编辑时可以选择一下命令处理:
      O只读打开,不改变文件内容
      E继续编辑文件,不恢复.swp文件保存的内容
      R将恢复上次编辑以后未保存文件内容
      Q退出vi
      D删除.swp文件
      或者使用vi -r 文件名来恢复未保存的内容




  • 相关阅读:
    通过request获取请求路径的不同方法的区别
    深入浅出:了解前后端分离优势、前后端接口联调以及优化问题
    java.lang.Exception: org.apache.http.conn.HttpHostConnectException: Connect to 172.24.1.227:80 [/172.24.1.227] failed: 拒绝连接 (Connection refused)
    MySQL数据库中时间类型总结
    ./startup.sh权限不够
    实体类如何不需要写set,get方法
    [算法] 八皇后——回溯问题
    【opencv】imread CV_LOAD_IMAGE_GRAYSCALE
    【算法】最长回文子串 longest palindrome substring
    【C++】双边滤波器(bilateral filter)
  • 原文地址:https://www.cnblogs.com/sonictl/p/6735642.html
Copyright © 2011-2022 走看看