工作中遇到的问题Python子线程退出

本文探讨了Python中线程异常处理机制。通过对比不同场景下线程类的设计,分析了当一个线程抛出异常时如何影响其他线程及主线程的行为。特别关注了异常传播与进程退出的区别。

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

如下代码:当线程ReqSender抛异常退出时,主线程一并退出。Timer里的get_t方法也退出

注意:ReqSender和Timer是两个线程类。


class MyError(Exception):
      print "a error"

class ReqSender():
    def __init__(self,ids,idb):
        self.ids=ids
        self.idb=idb

    def assert_case(self):
        if self.ids <> self.idb :
            try:
                raise MyError
            finally:
                exit(1)

class Timer():
    def get_t(self):
        for i in range(10):
            time.sleep(3)
            print i


if __name__ == '__main__':
    rs = ReqSender(2,3)
    tm = Timer()
    thread.start_new_thread(tm.get_t,())
    time.sleep(10)
    try:
        thread.start_new_thread(rs.assert_case,())
    except MyError:
        print "exist"
        sys.exit(1)

但当代码编程assert 和get_t同属于一个线程类。当assert方法异常退出。get_t并不会退出,而是等get_t跑完,主线程才退出。。

class MyError(Exception):
      print "a error"

class ReqSender():
    def __init__(self,ids,idb):
        self.ids=ids
        self.idb=idb

    def assert_case(self):
        if self.ids <> self.idb :
            try:
                raise MyError
            finally:
                exit(1)

    def get_t(self):
        for i in range(10):
            time.sleep(3)
            print i


if __name__ == '__main__':
    rs = ReqSender(2,3)
    thread.start_new_thread(rm.get_t,())
    time.sleep(10)
    try:
        thread.start_new_thread(rs.assert_case,())
    except MyError:
        print "exist"
        sys.exit(1)

这可能是一个线程,进程退出的问题。因为我对这块不太熟悉,所以mark以下,以后回来再思考深层原因。

转载于:https://my.oschina.net/greengirl/blog/156992

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值