我想看看程序何时使用Dtrace进入一个类。
例如:
dtrace -c './myProgram' -n 'pid$target:myProgram:function:entry'
当程序 myProgram 进入函数 function 时,它会触发, 现在,如何编写一个在程序进入类而不是函数时触发的探测器?
我试过了:
dtrace -c './myProgram' -n 'pid$target:myProgram:className:entry'
但它不起作用
答案 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 = ▭
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