如何查看一个进程中的某个线程是否存活?

简介: pthread_kill:   别被名字吓到,pthread_kill可不是kill,而是向线程发送signal。还记得signal吗,大部分signal的默认动作是终止进程的运行,所以,我们才要用signal()去抓信号并加上处理函数。

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_kill函数检测一个线程是否还活着的程序,在linux环境下gcc编译通过,现将代码贴在下面:

    /******************************* pthread_kill.c *******************************/

    #include <stdio.h>

    #include <stdlib.h>

    #include <pthread.h>

    #include <errno.h>

    void *func1()/*1秒钟之后退出*/

    {

    sleep(1);

    printf("线程1(ID:0x%x)退出。/n",(unsigned int)pthread_self());

    pthread_exit((void *)0);

    }

    void *func2()/*5秒钟之后退出*/

    {

    sleep(5);

    printf("线程2(ID:0x%x)退出。/n",(unsigned int)pthread_self());

    pthread_exit((void *)0);

    }

    void test_pthread(pthread_t tid) /*pthread_kill的返回值:成功(0) 线程不存在(ESRCH) 信号不合法(EINVAL)*/

    {

    int pthread_kill_err;

    pthread_kill_err = pthread_kill(tid,0);

    if(pthread_kill_err == ESRCH)

    printf("ID为0x%x的线程不存在或者已经退出。/n",(unsigned int)tid);

    else if(pthread_kill_err == EINVAL)

    printf("发送信号非法。/n");

    else

    printf("ID为0x%x的线程目前仍然存活。/n",(unsigned int)tid);

    }

    int main()

    {

    int ret;

    pthread_t tid1,tid2;

    pthread_create(&tid1,NULL,func1,NULL);

    pthread_create(&tid2,NULL,func2,NULL);

    sleep(3);/*创建两个进程3秒钟之后,分别测试一下它们是否还活着*/

    test_pthread(tid1);/*测试ID为tid1的线程是否存在*/

    test_pthread(tid2);/*测试ID为tid2的线程是否存在*/

    exit(0);

    }

    编译:gcc -o pthread_kill -lpthread pthread_kill.c

    运行:./pthread_kill

    ///////////////////////// 运行结果 /////////////////////////////

    线程1(ID:0xb7e95b90)退出。

    ID为0xb7e95b90的线程不存在或者已经退出。

    ID为0xb7694b90的线程目前仍然存活。

目录
相关文章
|
15天前
|
安全 Python
告别低效编程!Python线程与进程并发技术详解,让你的代码飞起来!
【7月更文挑战第9天】Python并发编程提升效率:**理解并发与并行,线程借助`threading`模块处理IO密集型任务,受限于GIL;进程用`multiprocessing`实现并行,绕过GIL限制。示例展示线程和进程创建及同步。选择合适模型,注意线程安全,利用多核,优化性能,实现高效并发编程。
28 3
|
15天前
|
安全 数据安全/隐私保护 数据中心
Python并发编程大挑战:线程安全VS进程隔离,你的选择影响深远!
【7月更文挑战第9天】Python并发:线程共享内存,高效但需处理线程安全(GIL限制并发),适合IO密集型;进程独立内存,安全但通信复杂,适合CPU密集型。使用`threading.Lock`保证线程安全,`multiprocessing.Queue`实现进程间通信。选择取决于任务性质和性能需求。
28 1
|
15天前
|
Python
解锁Python并发新世界:线程与进程的并行艺术,让你的应用性能翻倍!
【7月更文挑战第9天】并发编程**是同时执行多个任务的技术,提升程序效率。Python的**threading**模块支持多线程,适合IO密集型任务,但受GIL限制。**multiprocessing**模块允许多进程并行,绕过GIL,适用于CPU密集型任务。例如,计算平方和,多线程版本使用`threading`分割工作并同步结果;多进程版本利用`multiprocessing.Pool`分块计算再合并。正确选择能优化应用性能。
|
10天前
|
消息中间件 安全 数据处理
Python中的并发编程:理解多线程与多进程的区别与应用
在Python编程中,理解并发编程是提高程序性能和响应速度的关键。本文将深入探讨多线程和多进程的区别、适用场景及实际应用,帮助开发者更好地利用Python进行并发编程。
|
16天前
|
数据处理 调度 Python
Python并发编程实战指南:深入理解线程(threading)与进程(multiprocessing)的奥秘,打造高效并发应用!
【7月更文挑战第8天】Python并发编程探索:使用`threading`模块创建线程处理任务,虽受限于GIL,适合I/O密集型工作。而`multiprocessing`模块通过进程实现多核利用,适用于CPU密集型任务。通过实例展示了线程和进程的创建与同步,强调了根据任务类型选择合适并发模型的重要性。
|
14天前
|
数据库 数据安全/隐私保护 C++
Python并发编程实战:线程(threading)VS进程(multiprocessing),谁才是并发之王?
【7月更文挑战第10天】Python并发对比:线程轻量级,适合I/O密集型任务,但受GIL限制;进程绕过GIL,擅CPU密集型,但通信成本高。选择取决于应用场景,线程利于数据共享,进程利于多核利用。并发无“王者”,灵活运用方为上策。
|
15天前
|
安全 API 调度
深度剖析:Python并发编程中的线程与进程,那些你不可不知的使用技巧与限制!
【7月更文挑战第9天】Python并发:线程适合IO密集型任务,利用GIL下的多线程同步,如示例中使用锁。进程适用于CPU密集型,通过multiprocessing模块实现多进程,利用进程间通信如队列。线程受限于GIL,进程间通信成本高。选择取决于任务需求和性能目标。
16 2
|
16天前
|
大数据 API 数据处理
Python高手都在用的并发秘籍:解锁线程与进程的终极奥义,性能飙升不是梦!
【7月更文挑战第8天】Python并发编程提升性能,线程(threading)适合I/O密集型任务,如网络请求,通过`start()`和`join()`实现并发。进程(multiprocessing)利用多核CPU,适用于CPU密集型任务,如大数据处理。结合两者可优化混合任务,实现最佳并发效果。
16 1
|
19天前
|
消息中间件 安全 Java
线程和进程的区别及应用场景
线程和进程的区别及应用场景
|
23天前
|
消息中间件 安全 Java
线程和进程的区别及应用场景
线程和进程的区别及应用场景

相关实验场景

更多