之前一直纠结于这两个函数之间是否存在竞争条件:如果先执行pthread_join(...),那么该线程将阻塞,直到指定的线程调用pthread_exit、从启动例程中返回或者被取消。但是,如果线程1先执行pthread_exit(...),那么线程2执行pthread_join(tid1,..)获取线程1 的退出状态时会不会因为线程1已经结束而无法获得线程1的退出状态而一直阻塞下去?
其实不会,因为pthread_exit和pthread_join函数的无类型指针传递的结构的地址所使用的内存在调用者完成调用以后必须仍然是有效的,否则就会出现或无效或非法内存访问。这需要编程人员注意,最容易犯这种错误的情况是,线程在自己的栈上分配了一个结构然后把指向这个结构的指针传给pthread_exit,那么调用者pthread_join的线程试图使用该结构时,这个栈可能已经被撤销,这块内存也已经另作他用。