首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >仪器时间分析器:<称为堆栈限制reached>是什么意思?我能控制限度吗?

仪器时间分析器:<称为堆栈限制reached>是什么意思?我能控制限度吗?
EN

Stack Overflow用户
提问于 2014-09-17 09:02:33
回答 1查看 1.6K关注 0票数 2

当我的程序执行深度递归算法时,“仪器中的时间分析器”创建了一个名为<Call stack limit reached>的新入口点函数。我猜这意味着时间分析器在采样时对当前堆栈进行回溯时有一定的限制。

我能控制这个限制吗?如果是这样的话,是怎么做的?

编辑

我尝试过Preferences->DTrace->Max Backtrace Depth设置,但它似乎没有效果。

下面是一个具有深度递归的短程序,它可以达到定义的深度,并在那里花费一段时间:

代码语言:javascript
复制
#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的数字。

EN

回答 1

Stack Overflow用户

发布于 2014-09-18 18:46:04

您可以在DTrace部分中根据仪器的首选项设置最大调用堆栈深度。初始调用堆栈限制为128。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25886337

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档