Python报错: Unhandled exception in thread started by Error in sys.excepthook

本文介绍了一个Python多线程程序中出现的问题及解决方案。主要讨论了如何避免因主线程提前退出导致子线程异常终止的情况,通过使用锁和循环检测来确保所有子线程正常完成。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天要写个简单脚本,模拟同时50个用户往服务器上传东西。

就简单用

thread.start_new_thread(func, ())

结果运行的时候报错:

Unhandled exception in thread started by 
Error in sys.excepthook: 
Original exception was:

想了一下,原来是子线程还没退出,主线程就退出了,需要确保主线程等待所有子线程退出后再退出,如果主线程比子线程早结束,子线程就会中断,抛出这个异常。简单加个sleep,就没有报错了,当然,比较好的方法是给每个线程都加了一把锁,直到线程运行结束,再释放这个锁。同时在Python的main线程中用一个while循环来不停的判断每个线程锁已释放

 locks=[];    
 for i in range(len(seconds)) :    
     lock=thread.allocate_lock();    
     lock.acquire();    
     locks.append(lock);   

启动线程的时候把锁传进去:

 thread.start_new_thread(loop,(function,(),lock));
在线程函数里面使用

lock.release(); 

在主线程里面使用while循环来检测锁是否都释放了

for lock in locks :    
    while lock.locked() :     
        pass;


OK,这样就搞定了。





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值