
当我的程序执行深度递归算法时,“仪器中的时间分析器”创建了一个名为<Call stack limit reached>的新入口点函数。我猜这意味着时间分析器在采样时对当前堆栈进行回溯时有一定的限制。
我能控制这个限制吗?如果是这样的话,是怎么做的?
编辑
我尝试过Preferences->DTrace->Max Backtrace Depth设置,但它似乎没有效果。
下面是一个具有深度递归的短程序,它可以达到定义的深度,并在那里花费一段时间:
#define RECURSION_DEPTH 200
void recurse( unsigned const depth )
{
if( RECURSION_DEPTH == depth ) for( unsigned i = 0; i < 1000000000; ++i );
else recurse( depth + 1 );
}
int main()
{
recurse( 1 );
return 0;
}当我对这个程序进行时间分析时,我会继续看到<Call stack limit reached>现象,即使我将DTrace首选项设置为大于200的数字。
发布于 2014-09-18 18:46:04
您可以在DTrace部分中根据仪器的首选项设置最大调用堆栈深度。初始调用堆栈限制为128。

https://stackoverflow.com/questions/25886337
复制相似问题