这是pthread_create的声明:
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *
(*start_routine) (void *), void *arg);
它包含一个函数start_routine。
所以当我们调用pthread_create时,函数将使用param arg执行。
那么为什么需要调用pthread_join(),因为要执行start_routine函数?
我也尝试不包括pthread_join()函数,确实根本没有执行start_routine函数,并且该进程在创建后才退出。
那么当程序来到pthread_create时,究竟会发生什么呢? param start_routine的执行是否有条件?
混乱...
这是我的测试代码:
#include <pthread.h>
#include <stdio.h>
int sum;
void* runner(void *param);
int main(int argc, char *argv[])
{
pthread_t tid; //The thread identifier
pthread_attr_t attr;//set of thread attributes
if(argc!=2){
fprintf(stderr, "usage:a.out <integer value>\n");
return -1;
}
if(atoi(argv[1])<0){
fprintf(stderr, "%d must be <=0\n",atoi(argv[1]));
return -1;
}
//get the default attributes
pthread_attr_init(&attr);
//create the thread
pthread_create(&tid,&attr,runner,argv[1]);
//now wait for the thread to exit
pthread_join(tid,NULL);
printf("sum=%d\n", sum);
}
void* runner(void *param)
{
int i,upper = atoi(param);
sum=0;
for(i=1;i<=upper;i++)
sum+=i;
pthread_exit(0);
}
答案 0 :(得分:0)
如果在pthread_join之前退出应用程序或进程,则进程不会等待start_routine
应用程序完成执行。它将与所有资源一起杀死线程
答案 1 :(得分:0)
如果您可以共享测试代码,包括pthread_create()和start_routine()的调用者,将会有所帮助。