溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何解決Python設(shè)置函數(shù)調(diào)用超時,進程卡住的問題

發(fā)布時間:2021-07-30 13:53:14 來源:億速云 閱讀:227 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下如何解決Python設(shè)置函數(shù)調(diào)用超時,進程卡住的問題,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

背景:

最近寫的Python代碼不知為何,總是執(zhí)行到一半卡住不動,為了使程序能夠繼續(xù)運行,設(shè)置了函數(shù)調(diào)用超時機制。

代碼:

import time
import signal
 
 
def test(i):
 time.sleep(i % 4)
 print "%d within time" % (i)
 return i
 
 
if __name__ == '__main__':
 def handler(signum, frame):
 raise AssertionError
 
 
for i in range(1, 10):
 try:
  signal.signal(signal.SIGALRM, handler)
  signal.alarm(3)
  test(i)
 except AssertionError:
  print "%d timeout" % (i)
 finally:
  signal.alarm(0)
  signal.signal(signal.SIGALRM, signal.SIG_DFL)

說明:

1、調(diào)用test函數(shù)超時監(jiān)控,使用sleep模擬函數(shù)執(zhí)行超時

2、引入signal模塊,設(shè)置handler捕獲超時信息,返回斷言錯誤

3、alarm(3),設(shè)置3秒鬧鐘,函數(shù)調(diào)用超時3秒則直接返回

4、捕獲異常,打印超時信息

程序執(zhí)行結(jié)果:

1 within time
2 within time
3 timeout
4 within time
5 within time
6 within time
7 timeout
8 within time
9 within time

看完了這篇文章,相信你對“如何解決Python設(shè)置函數(shù)調(diào)用超時,進程卡住的問題”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI