判断线程是否已经结束

一 代码

#include <iostream>  
#include <pthread.h>  
#include <signal.h>  
#include <unistd.h> //sleep
#include "errno.h"
using namespace std;

void *thfunc(void *arg)   // 线程函数
{
    int tm = 50;
    while (1)
    {
        cout << "thrfunc--left:"<<tm<<" s--" <<endl;
        sleep(1);
        tm--;
    }
    return (void *)0;   
}

int main(int argc, char *argv[])
{
    pthread_t     pid;  
    int res;
    
    res = pthread_create(&pid, NULL, thfunc, NULL);   // 创建线程
    sleep(5);
    int kill_rc = pthread_kill(pid, 0);   // 发送信号0,探测线程是否存活

    // 打印探测结果
    if (kill_rc == ESRCH)
        cout<<"the specified thread did not exists or already quit\n";
    else if (kill_rc == EINVAL)
        cout<<"signal is invalid\n";
    else
        cout<<"the specified thread is alive\n";
     
    return 0;
}

二 运行

在 Python 中,判断线程是否运行结束有多种方法: 1. **使用 `join()` 方法**:`join()` 方法可使主线程在目标线程完成之前保持等待状态。示例代码如下: ```python import threading import time def test_function(): time.sleep(2) print("线程执行完毕") thread = threading.Thread(target=test_function) thread.start() # 主线程等待子线程结束 thread.join() print("子线程结束,主线程继续执行") ``` 2. **使用 `is_alive()` 方法**:`is_alive()` 方法可以灵活地检查线程是否还在运行。示例代码如下: ```python import threading import time def test_function(): time.sleep(2) print("线程执行完毕") thread = threading.Thread(target=test_function) thread.start() while thread.is_alive(): print("线程还在运行") time.sleep(0.5) print("线程结束") ``` 3. **使用 `threading.enumerate()` 方法**:通过统计正在运行的线程数量来判断线程是否全部结束,当正在运行的线程数量为 1(即只有主线程)时,说明其他线程都已结束。示例代码如下: ```python import threading import time def test_function(): time.sleep(2) print("线程执行完毕") threads = [] for _ in range(3): thread = threading.Thread(target=test_function) thread.start() threads.append(thread) while True: if len(threading.enumerate()) == 1: break print('当前运行线程:', len(threading.enumerate())) time.sleep(1) print("所有线程结束") ``` 4. **使用闭锁(`CountDownLatch`)**:可以使用 `CountDownLatch` 来使一个或多个线程等待一组事件发生。不过 Python 标准库中没有直接的 `CountDownLatch` 实现,可通过 `threading.Semaphore` 模拟。示例代码如下: ```python import threading import time class CountDownLatch: def __init__(self, count): self.count = count self.semaphore = threading.Semaphore(0) def count_down(self): with threading.Lock(): self.count -= 1 if self.count == 0: for _ in range(self.semaphore._value): self.semaphore.release() def await_(self): if self.count > 0: self.semaphore.acquire() def test_function(latch): time.sleep(2) print("线程执行完毕") latch.count_down() latch = CountDownLatch(3) threads = [] for _ in range(3): thread = threading.Thread(target=test_function, args=(latch,)) thread.start() threads.append(thread) latch.await_() print("所有线程结束") ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值