Вопросы по 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(....);

Я проверил код в отдельном проекте, я вижу, что «привет» выводится из std, но как только я помещаю его в большой проект, «привет» выводится из err 🙁

Я использую xcode5.0 и смешивать c ++ и цель c. есть идеи по этому поводу?
Спасибо

0

Решение

Я нашел причину. Я реализовал printf с NSlogV прежде, и я забыл это. По умолчанию NSlogV выводит информацию в stderr. так что это причина. — Jet

0

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector