Re: threads
On Tue, 1 Aug 2000, Alexander Kotelnikov wrote:
> On Tue, Aug 01, 2000 at 01:09:27AM +0400, Peter Novodvorsky wrote:
> > ++ 01/08/00 01:03 +0400 - Alexander Kotelnikov:
> > > Hi,
> > >
> > > multithreaded программа делает Sefmentation fault, приотладки с gdb
> > > выясняется, что она получает "SIGTTOU", я как-то в первые с этим сигналом
> > > столкнулся, чтобы это могло значить? У программы две нитки, пишущие в stdout
> >
> > SIGTTOU Остановка фонового процесса, если он пытается записать данные
> > на свой управляющий терминал.
> >
> > (C) Terrence Chan.
>
> ну это еще и ``man 7 signal'' впрос почему это возникает.
>
> Есть некоторое чувство, что "главная" нитка каким-либо образом блокирует
> stdout для "побочной". Возникает это чувство из-за того, что программа не
> всегда получат Segfault'ы, но достаточно часто, чтобы обеспокоиться. При этом
> замечено, что если "главной" нитке увеличить жизнь, добавив sleep(3) в конце,
> то все перестает глючить напрочь.
У меня такая гипотеза: SIGTTOU программа получает только когда отлаживается
под gdb (так как от SITTOU программы не сегфаултятся и не падают - см. man 7
signal - их просто останавливают). Поэтому, если софтина падает по sefault,
значит ошибка происходит в другом месте. Я бы порекомендовал разрешить кидать
корки и посмотреть в корке где упала софтина:
gdb -c core-file-name или что-то типа того - я не помню (насколько я помню,
после запуска gdb таким образом надо набрать where и он скажет где софтина
упала).
И еще - я чувствую, что программа на С++ - поэтому я бы удостоверился, что
либы, которые используются обоими витками, мультинитевые (иначе программа
может падать в какой-то либе). Если используется STL, то надо определить
какой-то макрос - и т.д.
>
> --
> Alexander Kotelnikov
> Saint-Petersburg, Russia
>
Best regards,
-Vlad
Reply to:
- Follow-Ups:
- Re: threads
- From: "Dennis I. Chernoivanov" <cdi@sparc.spb.su>