我正在尝试构建自己的uClibc嵌入式系统。我遇到了一些问题,但2天后,我解决了所有这些问题。只剩下一个:pthread
无法正常工作。
这是一个简单的程序,来自python的configure脚本:
#include <pthread.h>
void* routine(void* p){return NULL;}
int main(){
pthread_t p;
if(pthread_create(&p,NULL,routine,NULL)!=0)
return 1;
(void)pthread_detach(p);
return 0;
}
在我的基于glibc的系统上,它运行然后退出。 但是在我的基于uclibc的系统上,它会运行,结束线程并冻结:
[Thread debugging using libthread_db enabled]
[New Thread 0x801 (LWP 17631)]
[New Thread 0x402 (LWP 17632)]
[Thread 0x402 (LWP 17632) exited]
[Thread 0x801 (LWP 17631) exited]
^C
Program received signal SIGINT, Interrupt.
0xb7f768e7 in sigsuspend () from /lib/libc.so.0
我尝试了新旧linuxthreads,但都没有奏效。你有什么想法吗?
编辑:
好的,我找到了更多信息:
#include <pthread.h>
#include <stdio.h>
void* routine(void* p){printf("AAA!\n");return NULL;}
int main(){
pthread_t p;
pthread_create(&p,NULL,&routine,NULL);
printf("BBB!");
(void)pthread_detach(p);
pthread_exit(0);
exit(0);
}
仅打印“AAA!”,然后冻结(glibc系统以随机顺序打印“AAA!”和“BBB!”)。所以我认为uclibc pthreads本身肯定会有一些错误。还有其他帮助吗? 尝试了一些其他的pthread测试,最后他们每个都冻结了。 编辑:我没有找到为什么这是hapenning,但我复制预编译的uclibc,它现在工作。
答案 0 :(得分:1)
如果你没有通过其他方式确保主线程是最后一个运行,main
需要在返回之前调用pthread_exit()
,等待所有其他线程终止。
如果没有其他线程在运行,那就变成了无操作,所以无论如何调用它都没有坏处。