linux程序设计——取消一个线程(第十二章)

原创 2015年07月07日 10:16:14

12.7    取消一个线程

有时,想让一个线程可以要求另一个线程终止,就像给它发送一个信号一样。线程有方法可以做到这一点,与与信号处理一样,线程可以被要求终止时改变其行为。
pthread_cancel是用于请求一个线程终止的函数
#inlude <pthread.h>
int pthread_cancel(pthread_t thread);
这个函数提供一个线程标识符就可以发送请求来取消它。
线程可以用pthread_setcancelstate设置线程的取消状态
#include <pthread.h>
int pthread_setcancelstate(int state, int *oldstate);
第一个参数的取值可以是PTHREAD_CANCEL_ENABLE,这个值允许线程接收取消请求;或者是PTHREAD_CANCEL_DISABLE,它的作用是忽略取消请求。oldstate指针用于获取先前的取消状态。
如果取消请求被接受了,线程就可以进入第二个控制层次,用pthread_setcanceltype设置取消类型
#include <pthread.h>
int pthread_setcanceltype(int type, int *oldtype);
type参数可以有两种取值:一个是PTHREAD_CANCEL_ASYNCHRONOUR,它将使得在接收到取消请求后立即采取行动;另一个是PTHREAD_CANCEL_DEFERRED,它将使得在接受到取消请求后,一直等待直到线程执行下述函数之一才采取行动。具体是函数pthread_join,pthread_cond_wait,pthread_cond_timedwait,pthread_testcancel,sem_wait或sigwait.
编写程序thread7.c,主线程向它创建的线程发送一个取消请求。
/*************************************************************************
 > File Name:    thread7.c
 > Description:  thread7.c程序在主线程中向它创建的新线程发送一个取消请求
 > Author:       Liubingbing
 > Created Time: 2015/7/7 9:58:40
 > Other:        thread7.c程序中新线程的调用函数中分别需要设置新线程的取消状态和取消类型
 ************************************************************************/

#include<stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <pthread.h>

void *thread_function(void *arg);

int main(){
	int res;
	pthread_t a_thread;
	void *thread_result;
	/* pthread_create函数创建新线程,新线程标识符保存在a_thread,新线程调用的函数为thread_function,函数的参数为NULL */
	res = pthread_create(&a_thread, NULL, thread_function, NULL);
	if (res != 0) {
		perror("Thread creation failed");
		exit(EXIT_FAILURE);
	}

	sleep(3);
	printf("Canceling thread...\n");
	/* pthread_cancel函数请求线程a_thread终止 */
	res = pthread_cancel(a_thread);
	if (res != 0) {
		perror("Thread cancelation failed");
		exit(EXIT_FAILURE);
	}
	printf("Waiting for thread to finish...\n");
	/* pthread_join等待线程a_thread与主线程重新合并 */
	res = pthread_join(a_thread, &thread_result);
	if (res != 0) {
		perror("Thread join failed");
		exit(EXIT_FAILURE);
	}
	exit(EXIT_SUCCESS);
}

void *thread_function(void *arg) {
	int i, res;
	/* pthread_setcancelstate函数设置线程的取消状态,PTHREAD_CANCEL_ENABLE允许线程接收取消请求;PTHREAD_CANCEL_DISABLE忽略取消请求 */
	res = pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL);
	if (res != 0) {
		perror("Thread pthread_setcancelstate failed");
		exit(EXIT_FAILURE);
	}
	/* pthread_setcanceltype函数设置线程的取消类型,PTHREAD_CANCEL_DEFERRED将使得在接收到取消请求后,一直等待直到线程执行某个函数(如pthread_join)之后才采取行动 */
	res = pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL);
	if (res != 0) {
		perror("Thread pthread_setcanceltype failed");
		exit(EXIT_FAILURE);
	}
	printf("thread_function is running\n");
	for (i = 0; i < 10; i++){
		printf("Thread is still running (%d)...\n", i);
		sleep(1);
	}
	pthread_exit(0);
}
以通常的方法创建新线程后,主线程休眠一会儿(好让新线程有时间开始执行),然后发送一个取消请求,如下所示:
sleep(3);
printf("Canceling thread...\n");
res = pthread_cancel(a_thread);
在新创建的线程中,首先将取消状态设置为允许取消,如下所示:
res = pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL);
然后将取消类型设置为延迟取消,如下所示:
res = pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL);
最后,线程在循环中等待被取消,如下所示:
for (i = 0; i < 10; i++) {
    printf("Thread is still running (%d)...\n", i);
    sleep(1);
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

linux程序设计——多线程(第十二章)

12.8    多线程 之前,总是让程序的主线程仅仅创建一个线程,这节将演示如何在同一个程序中创建多个线程,然后如何以不同于其启动顺序将它们合并在一起。此外,还演示多线程编程时容易出现的时序问题. ...

linux程序设计——同时执行的线程(第十二章)

12.4    同时执行 接下来编写一个程序来验证两个线程的执行是同时执行的(当然,如果是在一个单处理器系统上,线程的同时执行就需要靠CPU在线程之间的快速切换来实现).这个程序中,在两个线程之间使用...

UNIX网络编程卷1 服务器程序设计范式6 并发服务器,为每个客户请求创建一个线程

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie 1.为每个客户请求创建一个线程,以取代为每个客户派生一个子进程 /*...
  • zhsenl
  • zhsenl
  • 2014年08月26日 11:51
  • 837

《java语言程序设计》第十二章学习总结

异常处理和文本I/O

《Erlang 程序设计》练习答案 -- 第十二章 并发编程

% (1).编写一个start(AnAtom, Fun)函数来把spawn(Fun)注册为AnAtom。 % 确保当两个并行的进程同时执行start/2时你的程序也能正确工作。 % 在这种情况下,必须...

java语言程序设计 第十二章 (12.11、12.12、12.13、12.14)

程序小白,希望和大家多交流,共同学习 import java.util.Scanner; import java.io.File; import java.io.PrintWriter;publi...

java 语言程序设计 第十二章(12.1、12.2、12.3、12.4、12.5、12.6)

程序小白,希望和大家多交流,共同学习 public class CountWithException { public static void main(String[] args) ...

[学习笔记—Objective-C]《Objective-C 程序设计 第6版》第十二章 预处理程序

Part 1. #define语句 #define语句的基本用途之一是给符号名称指定程序常量。类似于文本编辑器中的搜索和替换。 优点记忆成本低:不必特意记住常量的值 更改便携性:只需在一个地方更改常量...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:linux程序设计——取消一个线程(第十二章)
举报原因:
原因补充:

(最多只允许输入30个字)