Linux--多线程之线程的取消pthread_cancel
2016-12-03 19:43
513 查看
#include "apue.h" /** pthread_cancel(pthread_t tid) 取消tid指定的线程 成功返回0 取消只是发送一个请求 会不正常的终止线程 pthread_setcancelstate(int state,int *oldstate) 设置本线程对cancel信号的反应 state有两种值 PTHREAD_CANCEL_ENABLE(缺省) 和PTHREAD_CANCEL_DISABLE 分别表示收到信号后设置为 canceled 状态和忽略cancel信号继续运行 oldstate 不为NULL则存入原来的cancel状态 pthread_setcanceltype(int type,int *oldtype) 设置调用线程取消动作的执行时机,type可以为 PTHREAD_CANCEL_DEFERRED 和 PTHREAD_CANCEL_ASYCHRONOUS 仅当cancel状态为enable时 有效 分别表示收到信号后继续运行到下一个 取消点然后退出和立即退出 oldtype 如果不为NULL则存入原来的取消动作类型 线程的默认状态为可以处理信号 并且以PTHREAD_CANCEL_DEFERRED 的策略执行 */ /** 测试线程 对线程取消信号的默认处理方式 */ void *thread_fun(void *person1){ //打印 int i=0; for(;i<5;i++) { //执行结果不稳定而且很大的几率 两次打印相同的i printf("I am lived i=%d\n",i);//取消点 usleep(1); } return (void *)1; } int main(){ pthread_t tid; int err,cval; //创建线程 err = pthread_create(&tid,NULL,thread_fun,NULL); if(err!=0){ perror(" fail to create thread "); return -1; } printf("success to create thread tid = %lu \n ",tid); //发送 取消线程的消息 cval = pthread_cancel(tid); if(cval!=0) { perror("fail to cancel thread"); return -1; } printf(" succeed to send request to cancel thread \n"); //主线程退出 pthread_exit(NULL);//always succeeds }
相关文章推荐
- linux下pthread_cancel无法取消线程的原因
- linux下pthread_cancel无法取消线程的原因
- 防止死锁:采用linux多线程的pthread_cancel终止线程
- linux下pthread_cancel无法取消线程的原因
- linux下pthread_cancel无法取消线程的原因【转】
- pthread_cancel-linux 终止其他线程
- pthread_cancel引起线程死锁-linux
- 线程取消 (pthread_cancel)
- 线程取消(pthread_cancel)
- 线程取消(pthread_cancel)
- 线程取消 (pthread_cancel)
- 线程取消(pthread_cancel)
- 线程取消(pthread_cancel)
- 线程取消(pthread_cancel)
- Linux_ pthread 线程的取消
- pthread_cancel 线程取消以及锁的释放
- LInux多线程编程----线程属性pthread_attr_t
- 线程取消(pthread_cancel)
- 线程取消(pthread_cancel)
- Linux--多线程之线程连接pthread_join