fumingxiaoshen 2023-02-23 14:21 采纳率: 50%
浏览 22
已结题

python设置函数超时正常执行

最近想用python实现如下的一个功能,即设置函数的超时时间,当超过这个时间后函数退回到父函数而不会引发异常(导致整个程序结束)
如下的方式会导致整个程序停止执行
https://blog.csdn.net/qq_43994782/article/details/119033086

  • 写回答

2条回答 默认 最新

  • 神奇的代码在哪里 2023-02-23 18:26
    关注

    ①首先,我认真看了题主的链接,如果只是要不报错,加上异常处理就可以了,如下代码:

    import time
    import func_timeout
    from func_timeout import func_set_timeout
    
    @func_set_timeout(3)
    def task():
        while True:
            print('hello world')
            time.sleep(1)
    
    if __name__ == '__main__':
        try:
            task()
        except func_timeout.exceptions.FunctionTimedOut:
            print("执行已超时3秒")
    
    

    输出结果如下图:

    img

    ②这里发现另外一个问题,链接中的如下代码,其实还是会阻塞主线程。


    import time
    from func_timeout import func_set_timeout
    ​
    @func_set_timeout(1)
    def task():
        while True:
            print('hello world')
            time.sleep(1)
    ​
    if __name__ == '__main__':
        task()
    
    

    怎么验证呢,我们在task()后面加一句print("a"),如下代码:


    import time
    from func_timeout import func_set_timeout
    
    @func_set_timeout(3)
    def task():
        while True:
            print('hello world')
            time.sleep(1)
    
    if __name__ == '__main__':
        task()
        print("a")
    
    

    输出结果如下,发现控制台并没有打印字母a,所以题主按这个代码,还是会导致整个程序等待task()执行直到超时。

    img


    为了解决该问题,这里答主尝试启动多线程执行task(),代码如下:


    import time
    from func_timeout import func_set_timeout
    from threading import Thread
    
    @func_set_timeout(3)
    def task():
        while True:
            print('hello world')
            time.sleep(1)
    
    if __name__ == '__main__':
        t1 = Thread(target=task, args=())
        t1.start()
        print("a")
    
    

    程序运行结果,如下图:


    img


    发现程序并没有阻塞主线程成功在控制台打印了a,同时3秒后task()超时,抛出异常。
    但这里还是有一个问题,就是异常还没捕获和处理,这里加上异常处理代码,同时需要另外再写一个函数try_task()。
    完整代码如下:

    import time
    import func_timeout
    from func_timeout import func_set_timeout
    from threading import Thread
    
    
    def try_task():
        try:
            task()
        except func_timeout.exceptions.FunctionTimedOut:
            print("执行已超时3秒")
    
    
    @func_set_timeout(3)
    def task():
        while True:
            print('hello world')
            time.sleep(1)
          
    
    if __name__ == '__main__':
        t1 = Thread(target=try_task, args=())
        t1.start()
        print("a")
    
    
    

    输出结果如下图:

    img


    如果解答有用,请采纳~

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月8日
  • 已采纳回答 2月28日
  • 创建了问题 2月23日

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭