创建一个线程,printf()一些信息,
void *thread_dsp_comm(void *arg)
{
printf("in thread\n");
while (1) {
printf("I am here\n");
sleep_sec(1);
}
printf("thread exit\n");
return NULL;
}
在主线程中,cancel然后join,
pthread_cancel(m_thread);
pthread_join(m_thread, &res);
如果打开线程中的printf(),会导致pthread_join死机,线程也不会打印"I am here"
。即使你用信号量保护printf()也没有用。去掉printf(),一切正常。
可能是arm-2012.09-64-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2库的
原因。
void *thread_dsp_comm(void *arg)
{
printf("in thread\n");
while (1) {
printf("I am here\n");
sleep_sec(1);
}
printf("thread exit\n");
return NULL;
}
在主线程中,cancel然后join,
pthread_cancel(m_thread);
pthread_join(m_thread, &res);
如果打开线程中的printf(),会导致pthread_join死机,线程也不会打印"I am here"
。即使你用信号量保护printf()也没有用。去掉printf(),一切正常。
可能是arm-2012.09-64-arm-none-linux-gnueabi-i686-pc-linux-gnu.tar.bz2库的
原因。

探讨了在ARM环境下创建线程并使用printf进行输出时遇到的问题:当尝试取消并等待线程结束时,若线程中有printf调用,则会引发死锁,且无法打印预期信息。
2124

被折叠的 条评论
为什么被折叠?



