首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >关于Linux中的forking的问题

关于Linux中的forking的问题
EN

Stack Overflow用户
提问于 2011-05-03 16:59:48
回答 2查看 233关注 0票数 0

我现在正在学习操作系统,我有这段代码,但我收到了无限循环的递归调用,我只想创建一些son的,并计算fibonacci(小数字),我不明白为什么son根本不能完成,提前谢谢:

代码语言:javascript
复制
int fibonaci(int n) {
    if(n < 2){
        return n;
    } 
    return fibonaci(n - 1) + fibonaci(n - 2);
}

int main(int argc, char* argv[]) {

        //some checkings, and variables

    for (i = 0; i < argc; ++i) {
        son_pid = fork();
        if (son_pid == 0) {
            fibonaci(var); //var is some finite variable
            break;
        } 
    }
        if(son_pid != 0){
                while(wait(&status) != -1){}
        }
        return 0;
}

编辑过的

所有检查都已完成,问题出在逻辑上!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-05-04 01:28:19

这可能不是解决方案,但请尝试使用返回0而不是中断;

我确实认为问题出在派生/对待son vs parent代码中。我不明白你为什么把断点放在那里。计算了斐波纳契数后,儿子应该会回来。中断可能会产生一些不想要的结果。

票数 0
EN

Stack Overflow用户

发布于 2011-05-04 06:18:00

wait()"default behavior"将立即返回-1,如果它没有可以杀死的孩子,正如您所预期的那样:

wait():成功时,返回被终止的子进程的进程ID;出错时,返回-1。

ECHILD (for wait())调用进程没有任何未等待的子级。

我的快速测试证实了这个程序是有效的。但是,wait()的行为可能会有一些变化。

从好的方面来说,你知道你fork()'d了多少个孩子(argc wait() )。因此,wait()循环的一个更正确的版本是:

代码语言:javascript
复制
if (son_pid) {
    int i, status;
    for (i = 0; i < argc; i++) {
        wait(&status);
    }
}

我希望这能帮到你。

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

https://stackoverflow.com/questions/5867284

复制
相关文章

相似问题

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