我遇到一个关于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。对此有何想法? 感谢
答案 0 :(得分:0)
我找到了原因。我之前用NSlogV实现了printf,但我忘了。 NSlogV默认似乎输出信息到stderr。这就是原因。 - Jet