pthread_kill和pthread_cancel
来源:互联网 发布:python 连接数据库 编辑:程序博客网 时间:2024/05/13 01:26
pthread_kill和pthread_cancel
为了讲述标题两个函数,必须先介绍一下pthread线程库。
pthread线程库是遵循POSIX标准开发的,工作非常稳定,性能也不差,
所以在Linux下是最常用的线程库。但从调用上看,pthread线程应该仍然属于用户级的线程库,
其实用户级还是内核级的关键区别只在于线程的调度是由内核还是用户库来完成,用户级对于
一般的服务器工作而言是没用问题的。
pthread_kill函数的功能是向指定线程发送信号,信号为0时用于检查此线程ID的线程是否存活。
pthread_cancel函数的功能是给线程发送取消信号,使线程从取消点退出。
从函数功能上理解没用任何问题,但实际应用中发现创建线程超过3个,且一起退出时会发生异
常操作;分别对应两个函数进行测试,发现每个函数执行时如果线程已经退出,都会出现异常
情况。比较奇怪的是跟创建的线程数量有关,超过3个才发生;小于3个不发生,具体的原因不清楚。
另外测试给这两个函数错误的线程ID,也会造成异常的情况;线程ID正确,且没用退出则没用问题。
没用办法,只好修改了自己的实现函数,在每个线程退出后不再调用标题函数。对于线程保存的数据
结构,每个线程仅休眠500ms,就删除对应的数据,测试没用发现问题。500ms是多次测试的经验值,
一般线程都可以正常退出了。
pthread_kill:
别被名字吓到,pthread_kill可不是kill,而是向线程发送signal。还记得signal吗,
大部分signal的默认动作是终止进程的运行,所以,我们才要用signal()去抓信号并加上处理函数。
int pthread_kill(pthread_t thread, int sig);
向指定ID的线程发送sig信号,如果线程代码内不做处理,则按照信号默认的行为影响整个进程,
也就是说,如果你给一个线程发送了SIGQUIT,但线程却没有实现signal处理函数,则整个进程退出。
pthread_kill(threadid, SIGKILL)也一样,杀死整个进程。
如果要获得正确的行为,就需要在线程内实现signal(SIGKILL,sig_handler)了。
所以,如果int sig的参数不是0,那一定要清楚到底要干什么,而且一定要实现线程的信号处理函数,
否则,就会影响整个进程。
OK,如果int sig是0呢,这是一个保留信号,一个作用是用来判断线程是不是还活着。
我们来看一下pthread_kill的返回值:
成功:0
线程不存在:ESRCH
信号不合法:EINVAL
所以,pthread_kill(threadid,0)就很有用啦。
int kill_rc = pthread_kill(thread_id,0);
if(kill_rc == ESRCH)
printf("the specified thread did not exists or already quit\n");
else if(kill_rc == EINVAL)
printf("signal is invalid\n");
else
printf("the specified thread is alive\n");
上述的代码就可以判断线程是不是还活着了。
为了讲述标题两个函数,必须先介绍一下pthread线程库。
pthread线程库是遵循POSIX标准开发的,工作非常稳定,性能也不差,
所以在Linux下是最常用的线程库。但从调用上看,pthread线程应该仍然属于用户级的线程库,
其实用户级还是内核级的关键区别只在于线程的调度是由内核还是用户库来完成,用户级对于
一般的服务器工作而言是没用问题的。
pthread_kill函数的功能是向指定线程发送信号,信号为0时用于检查此线程ID的线程是否存活。
pthread_cancel函数的功能是给线程发送取消信号,使线程从取消点退出。
从函数功能上理解没用任何问题,但实际应用中发现创建线程超过3个,且一起退出时会发生异
常操作;分别对应两个函数进行测试,发现每个函数执行时如果线程已经退出,都会出现异常
情况。比较奇怪的是跟创建的线程数量有关,超过3个才发生;小于3个不发生,具体的原因不清楚。
另外测试给这两个函数错误的线程ID,也会造成异常的情况;线程ID正确,且没用退出则没用问题。
没用办法,只好修改了自己的实现函数,在每个线程退出后不再调用标题函数。对于线程保存的数据
结构,每个线程仅休眠500ms,就删除对应的数据,测试没用发现问题。500ms是多次测试的经验值,
一般线程都可以正常退出了。
pthread_kill:
别被名字吓到,pthread_kill可不是kill,而是向线程发送signal。还记得signal吗,
大部分signal的默认动作是终止进程的运行,所以,我们才要用signal()去抓信号并加上处理函数。
int pthread_kill(pthread_t thread, int sig);
向指定ID的线程发送sig信号,如果线程代码内不做处理,则按照信号默认的行为影响整个进程,
也就是说,如果你给一个线程发送了SIGQUIT,但线程却没有实现signal处理函数,则整个进程退出。
pthread_kill(threadid, SIGKILL)也一样,杀死整个进程。
如果要获得正确的行为,就需要在线程内实现signal(SIGKILL,sig_handler)了。
所以,如果int sig的参数不是0,那一定要清楚到底要干什么,而且一定要实现线程的信号处理函数,
否则,就会影响整个进程。
OK,如果int sig是0呢,这是一个保留信号,一个作用是用来判断线程是不是还活着。
我们来看一下pthread_kill的返回值:
成功:0
线程不存在:ESRCH
信号不合法:EINVAL
所以,pthread_kill(threadid,0)就很有用啦。
int kill_rc = pthread_kill(thread_id,0);
if(kill_rc == ESRCH)
printf("the specified thread did not exists or already quit\n");
else if(kill_rc == EINVAL)
printf("signal is invalid\n");
else
printf("the specified thread is alive\n");
上述的代码就可以判断线程是不是还活着了。
0 0
- pthread_kill和pthread_cancel
- pthread_kill和pthread_cancel
- pthread_kill和pthread_cancel
- pthread_kill和pthread_cancel
- pthread_kill和pthread_cancel
- pthread_cancel 和pthread_kill的区别
- pthread_kill()和pthread_cancel()的用法
- pthread_kill pthread_cancel
- pthread_kill 与pthread_cancel使用方法
- 线程正常终止pthread_exit,pthread_join,pthread_kill,pthread_cancel,sigwait,sigaddset
- pthread_kill 和 sigaction 函数
- pthread_kill 和 sigaction 函数
- pthread_kill 和 sigaction 函数
- pthread_kill 和 sigaction 函数
- pthread_kill 和 sigaction 函数
- pthread_cancel()和取消点
- pthread_kill
- pthread_kill函数 和 sigaction 函数
- Java Number类(数据类型的包装类)
- 安装 docker-regsitry
- linux php,oci8扩展
- flash中的世界坐标系和stage3D坐标系的关系
- 【poj 1741】tree 树的点分治
- pthread_kill和pthread_cancel
- iOS开发 - 如何申请快速审核
- swift3.0 自动消失提示框----吐司
- Going Home
- docker pull push到docker-regsitry上
- 移动端布局之REM,以及实际使用总结
- MySQL sql_mode设置
- (4.6.19)Android数据绑定框架DataBinding,堪称解决界面逻辑的黑科技
- L0/L1/L2范数的联系与区别