python中自定义超时异常的方法

带有返回值的超时异常,可以通过创建thread类的方式来进行捕捉

import threading
import sys
import time


class Dispacher(threading.Thread):
    def __init__(self, fun, args):
        threading.Thread.__init__(self)
        self.setDaemon(True)
        self.result = None
        self.error = None
        self.fun = fun
        self.args = args

        self.start()

    def run(self):
        try:
            self.result = self.fun(self.args)
        except:
            self.error = sys.exc_info()


def test_fun(i):
    # time.sleep(4)
    a = i*i
    # b    
  return a
def main_fun():
    c = Dispacher(test_fun, 2)
    c.join(2)

    if c.isAlive():
        return "TimeOutError"
    elif c.error:
        return c.error[1]
    t = c.result
    return t

if __name__ == '__main__':
    fun = main_fun()
    print(fun)

显示结果:
  test_fun 执行时间大于设置的2秒时,会抛出TimeOutError
  test_fun 执行时间小于设置的2秒时,并且函数正常执行时,显示:4
  test_fun 里面出现比如 “b” 时,会抛出 global name ‘b’ is not defined 的异常
  

signal.alarm注意两点:一是signal信号机制要在linux上才能运行; 二是signal信号在主线程中才会会起作用

](signal.alarm注意两点:一是signal信号机制要在linux上才能运行; 二是signal信号在主线程中才会会起作用)

# coding=utf-8
import threading
import time


def myFunc():
    time.sleep(1)
    print("myFunc执行了")


if __name__ == '__main__':
    t = threading.Thread(target=myFunc)
    t.setDaemon(True)
    t.start()

    t.join(2)
    print("it's over")

显示结果:
  myFunc执行了
  it’s over
可以看出,子线程结束时,用时1秒,没有超过主线程设定的3秒,所以主线程与子线程都被执行了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值