1. 需要用到的库
<pthread.h>
pthread_create
pthread_attr_init
pthread_attr_destory
pthread_attr_setdetachstate
各个函数具体的用法可以查询google了解
2. 线程的分离状态和表述
在任何一个时间点上,线程是可结合的(joinable),或者是分离的(detached)。一个可结合的线程能够被其他线程收回其资源和杀死;在被其他线程回收之前,它的存储器资源(如栈)是不释放的。相反,一个分离的线程是不能被其他线程回收或杀死的,它的存储器资源在它终止时由系统自动释放
在默认情况下线程是非分离状态的,这种情况下,原有的线程等待创建的线程结束。只有当pthread_join()函数返回时,创建的线程才算终止,才能释放自己占用的系统资源。而分离线程不是这样子的,它没有被其他的线程所等待,自己运行结束了,线程也就终止了,马上释放系统资源。
3. 可分离函数
void *detachedThread(void *arg) {
printf("I'm detached thread : %d\n", pthread_self());
return (void*) 1;
}
4. 可结合函数
void *joinableThread(void *arg) {
printf("I'm joinable thread : %d\n", pthread_self());
return (void*) 2;
}
通过两个运行两个线程去执行上述任务,detachedThread的执行结果是不能join的,只有可结合函数才可以join
5. 完整代码如下所示
#include <pthread.h>
#include <stdio.h>
void *detachedThread(void *arg) {
printf("I'm detached thread : %d\n", pthread_self());
return (void*) 1;
}
void *joinableThread(void *arg) {
printf("I'm joinable thread : %d\n", pthread_self());
return (void*) 2;
}
int main() {
int err;
void *ret;
pthread_t tid1, tid2;
pthread_attr_t attr1, attr2;
pthread_attr_init(&attr1);
pthread_attr_setdetachstate(&attr1, PTHREAD_CREATE_DETACHED);
pthread_attr_init(&attr2);
pthread_attr_setdetachstate(&attr2, PTHREAD_CREATE_JOINABLE);
pthread_create(&tid1, &attr1, detachedThread, NULL);
pthread_create(&tid2, &attr2, joinableThread, NULL);
sleep(1);
if ((err = pthread_join(tid2, &ret)) != 0) {
fprintf(stderr, "thread 2 join fail :%s\n", strerror(err));
}
printf("%d\n", *((int**)&ret));
pthread_attr_destroy(&attr1);
pthread_attr_destroy(&attr2);
return 0;
}
6. 编译代码,运行结果如下所示:
gcc -o threadControl threadControl.c
./threadControl