资源的销毁远比创建来得困难,例如线程。线程终止有很多种方式,如自然退出,显式调用pthread_exit。但是执行退出的时机,线程可能阻塞在如read, write,pthread_cond_wait等接口, 无法自然退出。那么就只好发送cancel信号强行终止了,但是这种强行终止是有代价的,我们需要考虑好线程终止时资源的清理问题。
线程的接收cancel信号的处理受两个因素影响。首先是取消状态,通过pthread_setcancelstate设置,使能或者不使能。如果处于不使能状态时,那么取消线程状态请求将排队等待直到使能线程取消状态。如果处于使能状态,那么接下来的动作决定于取消类型。
线程取消类型通过pthread_setcanceltype设置,存在同步退出,取消点退出两种选择。同步退出意味着线程可以在任意时刻退出。默认行为是PTHREAD_CANCEL_DEFERRED,也就是接收到cancel信号后执行直到遇到取消点退出,像是pthread_cond_wait,read等阻塞型函数都是取消点,当然也可以通过pthread_testcancel手动防止取消点。关于属于取消点的函数可以通过man pthreads(7)获取列表。
示例代码如下所示,我们创建了线程threadproc;在线程开始new了char [1024]的数组,获取mutex,然后在线程里故意调用pthread_cond_wait使得线程阻塞。主线程创建线程小睡一会,保证创建的线程已经执行;然后对刚创建的子线程发送cancel信号,并等待其结束。
#include <stdio.h>
#include <pthread.h>
#