是否可以使用Dtrace探测C ++类中的条目?

时间:2015-03-24 02:11:57

标签: c++ class dtrace dynamic-analysis

我想看看程序何时使用Dtrace进入一个类。

例如:

dtrace -c './myProgram' -n 'pid$target:myProgram:function:entry'

当程序 myProgram 进入函数 function 时,它会触发, 现在,如何编写一个在程序进入类而不是函数时触发的探测器?

我试过了: dtrace -c './myProgram' -n 'pid$target:myProgram:className:entry' 但它不起作用

1 个答案:

答案 0 :(得分:2)

dtrace -c './main' -n 'pid$target:main::entry' -n 'pid$target:main::return'

通过这种方式,我可以输出在运行时调用的所有函数,它将在函数的输入和返回时触发。

我正在探测的代码是:

#include <iostream>
#include <stdlib.h>
#include <time.h>

using namespace std;

class Polygon {
  protected:
    int width, height;
  public:
    void set_values (int a, int b)
      { width=a; height=b; }
    virtual int area ()
      { return 0; }
};

class Rectangle: public Polygon {
  public:
    int area()
      { 
        foo();
        return width*height; 
     }
    void foo(){}
};

class Triangle: public Polygon {
  public:
    int area()
    { 
        foo();
        return width*height/2; 
      }
    void foo(){}
};

int main () {

    //initialize random seed
    srand(time(NULL));

    if(rand() % 2)
        {
            Rectangle rect;
            Polygon * ppoly = &rect;
            ppoly->set_values (4,5);
            ppoly->area();
        }
    else
        {
            Triangle trgl;
            Polygon * ppoly = &trgl;
            ppoly->set_values (4,5);
            ppoly->area();
        }
    return 0;
}

我得到的dtrace输出是这样的:

CPU     ID                    FUNCTION:NAME
  3 109401                       main:entry 
  3 109404       Triangle::Triangle():entry 
  3 109405         Polygon::Polygon():entry 
  3 109415        Polygon::Polygon():return 
  3 109414      Triangle::Triangle():return 
  3 109403 Polygon::set_values(int, int):entry 
  3 109413 Polygon::set_values(int, int):return 
  3 109406           Triangle::area():entry 
  3 109407            Triangle::foo():entry 
  3 109417           Triangle::foo():return 
  3 109416          Triangle::area():return 
  3 109411                      main:return 

现在我正在尝试使用Python脚本解析它并生成调用树的xml