分类: LINUX
2011-10-12 10:56:42
很多书上说,主线程要等待设置为分离线程的子线程结束才退出程序,但是如果main函数的最后是以 return 或exit结束的,那么,主线程很可能不等待分离线程执行完就已经退出了。
例如如下程序:
#include
#include
void * thread_func(void * arg)
{
pthread_t id = pthread_self();
printf("Thread 1 : %u start/n",id);
sleep(10);
fprintf(stderr,"Thread 1 :%u stop/n");
return NULL;
}
int main()
{
pthread_t thd1;
int ret;
pthread_attr_t attr;
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr,PTHREAD_CREATE_DETACHED);
ret=pthread_create(&thd1,&attr,thread_func,NULL);
pthread_attr_destroy(&attr);
if(ret != 0)
{
printf("Create thread 1 error!/n");
}
printf("Thread 1 : %u/n",thd1);
return 0; //此函数会导致主线程不等待分离线程。应该换成 pthread_eixt(NULL);
}
主线程中使用pthread_exit只会使主线程自身退出,产生的子线程继续执行;用return则所有线程退出。
子线程或主线程使用exit,则整个线程全部终止。(类似于kill -9 的效果)
因此以上要想让子线程总能完整执行(不会中途退出),
一种方法是在主线程中调用pthread_join对其等待,即 pthread_create/pthread_join/pthread_exit或return;
一种方法是在主线程退出时使用 pthread_exit,这样子线程能继续执行,即pthread_create /pthread_detach/pthread_exit;
还有一种 是pthread_create/pthread_detach/return,这时就要保证主线程不能退出,至少是子线程完成前不能退出。现在的项目中 用的就是第三种方法,主线程是一个死循环,子线程有的是死循环有的不是。
理论上说,pthread_exit()和线程宿体函数退出的功能是相同的,函数结束时会在内部自动调用pthread_exit()来清理线程相关的资源。但实际上二者由于编译器的处理有很大的不同。
在进程主函数(main())中调用pthread_exit(),只会使主函数所在的线程(可以说是进程的主线程)退出;而如果是return,编译器将使其调用进程退出的代码(如_exit()),从而导致进程及其所有线程结束运行。