#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
}

更多相关文章

  1. Linux多线程——异步
  2. linux c++ 多线程心得
  3. [置顶] 每天进步一点点——Linux中的线程局部存储(一)
  4. 在Linux中查找线程的CPU使用情况
  5. Linux Kernel 学习笔记8:同步与互斥之信号量
  6. 线程同步-生产者消费者问题
  7. Linux多线程总结
  8. Linux多线程实践(一)线程基本概念和理论
  9. Linux系统编程——进程间通信:信号中断处理

随机推荐

  1. 基本架构
  2. [Google Android] Creating Your Own Spe
  3. Android(安卓)Data Binding 技术
  4. Android 编译错误::app:transformClasses
  5. OpenCV在Android平台上的应用
  6. Android外派(安卓外派) — 长年提供安卓开
  7. android 用到的技巧集
  8. Android lint 删除无用图片文件和配置文
  9. 【Android】Java四种线程池的使用
  10. android 笔记 --- 自定义Android主题风格