线程传参,退出,等待,取消,资源清理,互斥问题
线程传参
常用方法是传递一个指针变量给子线程,子线程就可以访问对应指针指向的空间,除此之外还可以采用传递一个长整型的值给子线程,相当于指针的空间中存储了这个值。
线程结束
线程执行为pthread_exit(NULL)或线程函数中用return (void*)5。
线程等待
通过线程等待可拿到子线程返回值。线程等待分为两种情况,一种为返回char *p用*pthread_join(pthid,(void**)&p)来接,另一种返回值为整型数要用 long thread_ret,pthread_join(pthid,(void*)&thread_ret)。
线程取消
线程取消用pthread_cancel(pthid),但要注意cancel是异步的,cancel是否执行成功在cancel请求是否被成功排队,子线程走到取消点以后才能被cancel。如果线程实际测试cancel不掉,加入pthead_testcancel()。
资源清理
1、使用场景是在线程被cancel能够在清理函数中去释放资源。
2、原理为线程结束后会去检查清理函数栈中是否有清理函数,如果有,对应清理函数就会弹栈并执行。
3、触发场景分为三种情况:
【1】pthread_exit(NULL)
【2】pthread_cancel时
【3】线程自己执行到pthread_cleanup_pop(1)
互斥
互斥锁要这么应用,先定义一个变量pthread_mutex_t mutex;再使用pthread_mutex_init(&mutex,NULL),进行加锁操作pthread_mutex_lock(&mutex),进行解锁操作pthread_mutex_unlock(&mutex),最后销毁锁pthread_mutex_destroy(&mutex),锁是加锁状态时,销毁会报EBUSY错误,即销毁锁失败。