线程的取消。
功能:send a cancellation request to a thread
thread: 需要取消的子线程的ID号
默认创建的子线程都是可以响应取消请求。
例题: 主线程发送取消请求给子线程,看看子线程情况。
#include “head.h”
下面展示一些 内联代码片
。
void *routine(void *arg)
{
int i;
for(i=0;i<10;i++)
{
sleep(1);
printf("hello!\n");
}
}
int main()
{
pthread_t tid;
pthread_create(&tid,NULL,routine,NULL);
sleep(5);
pthread_cancel(tid);
pthread_join(tid,NULL);
return 0;
}
//下面展示一些 `内联代码片`。
设置线程的取消响应行为
设置取消信号状态(state): 响应取消 / 不响应取消
pthread_setcancelstate()
功能: set cancelability state
PTHREAD_CANCEL_ENABLE : 可以响应取消
PTHREAD_CANCEL_DISABLE : 不响应取消
oldstate: 原来的取消状态,不关注则填NULL
当线程处理不响应取消信号时,收到取消请求,是不会马上被取消,但是一旦恢复可以响应状态,那么线程就会马上被取消掉。
也就是取消请求会阻塞,而不是丢弃。
设置取消响应信号立即取消,还是延迟取消。
pthread_setcanceltype()
功能: set cancelability type
type:设置的类型
PTHREAD_CANCEL_DEFERRED -> 遇到下一个取消点才会取消
PTHREAD_CANCEL_ASYNCHRONOUS -> 立即取消
其实取消点就是一些函数,所谓延迟取消,就是收到取消请求后,不会马上取消,而是等待遇到取消点的函数才会响应取消。
取消点函数有:
man 7 pthreads
Cancellation Points
s
void *routine(void *arg)
{
pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED,NULL);
long i,j;
for(i=0;i<100000;i++)
{
for(j=0;j<100000;j++)
{
}
}
while(1)
{
fputc('a',stderr); //取消点
printf("hello!\n");
}
}
int main()
{
pthread_t tid;
pthread_create(&tid,NULL,routine,NULL);
pthread_cancel(tid);
printf("I send cancel to thread!\n");
pthread_join(tid,NULL);
return 0;
}
延迟取消时,遇到取消点之后,执行完取消点才会响应这个取消请求!