冲冲冲,O(∩_∩)O
1.获取线程自身的ID
1.pthread_t pthread_self(void);
2.成功返回调用线程的ID,不会失败
2.比较两个线程的ID
int pthread_t pthread_equal(pthread_t t1,pthread_t t2);
若参数t1何t2所标识的线程ID相等,则返回非零,否则返回0
3.终止线程
1.从线程过程函数中return
2.调用pthread_exit函数
void pthread_exit(void *retval);
retval 为想要return的地址
4.线程执行轨迹
1.同步方式(非分离方式):
创建线程之后调用pthread_join函数等待其终止,并释放线程资源.
2.异步方式(分离方式):
无需创建等待,线程终止后自行释放资源.
1).int pthread_detach(pthread_t thread);
使thread参数所标识的线程进入分离状态
处于分离状态的线程终止后自动释放线程资源,且不能被pthread_join函数等待.
成功返回0,失败返回错误码.
5.取消线程
1.int pthrad_cancel(pthread_t thread);
成功返回0,失败返回错误码.
注意:该函数只是向线程发出取消请求,并不等待线程终止.
缺省情况下,线程在取消请求以后,并不会立即终止,而是继续运行,直到其到达某个取消点,在取消点处会检查其自身是否已被取消了,
1:通过pthread_testcancel 调用已编程方式建立线程取消点。 2:线程等待pthread_cond_wait或pthread_cond_timewait中的特定条件。 3:被sigwait(2)阻塞的函数。 4:一些标准的库调用。通常这些调用包括线程可基于阻塞的函数。 default情况下,会启用取消功能。
————————————————
版权声明:本文为CSDN博主「落尘纷扰」的原创文章,遵循 CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接: https://blog.csdn.net/jasonchen_gbd/article/details/78674716