关于dup2和多线程的问题

时间:2013-12-18 01:04:19

标签: c++ c macos fork dup2

我遇到一个关于dup2和多线程的字符串问题,代码是这样的:

pipe out, err;
int forkpid = fork();

if (forkpid == 0) {
    dup2(out.writeFd, STDOUT_FILENO);
    dup2(err.writeFd, STDERR_FILENO);
    printf("hello\n");
}

do {
    int res = poll(&fds, 2, 200);
    if (res) {
        for (int i = 0; i < 2; i++) {
            bytes = read(fds[i].fd, buff, size);
            if (fds[i].fd == out.readFd)
                printf("out\n");
            if (fds[i].fd == err.readFd)
                printf("err\n");
        }
    }
} while(....);

我已经在一个单独的项目中测试了代码,我可以看到“hello”是从std输出的,但是一旦我把它放在一个大项目中,“hello”从err输出:(

我正在使用xcode5.0并混合使用c ++和objective c。对此有何想法? 感谢

1 个答案:

答案 0 :(得分:0)

我找到了原因。我之前用NSlogV实现了printf,但我忘了。 NSlogV默认似乎输出信息到stderr。这就是原因。 - Jet