python多線程下信號處理程序示例
本文實例為大家分享了python多線程下信號處理程序示例的具體代碼,供大家參考,具體內(nèi)容如下
下面是一個網(wǎng)上轉(zhuǎn)載的實現(xiàn)思路,經(jīng)過驗證,發(fā)現(xiàn)是可行的,就記錄下來。
思路
python多線程中要響應(yīng)Ctrl+C的信號以殺死整個進(jìn)程,需要:
1.把所有子線程設(shè)為Daemon;
2.使用isAlive()函數(shù)判斷所有子線程是否完成,而不是在主線程中用join()函數(shù)等待完成;
3.寫一個響應(yīng)Ctrl+C信號的函數(shù),修改全局變量,使得各子線程能夠檢測到,并正常退出。
源碼
#!/usr/bin/env python
#encoding: utf-8
#filename: signal_demo.py
import threading, signal
def do_job(i, step):
global exited
idx = i
while not exited:
if(idx < 10000000):
print 'thread[%d]: idx=%d' % (i, idx)
idx = idx + step
else:
break
if exited:
print 'receive a signal to exit, thread[%d] stop.' % i
else:
print 'thread[%d] complete.' % i
def sig_handler(sig, frame):
global exited
exited = True
print 'receive a signal %d, exited=%d' % (sig, exited)
def main():
#set signal handler
signal.signal(signal.SIGTERM, sig_handler)
signal.signal(signal.SIGINT, sig_handler)
pool = []
pool_size = 50
for i in range(pool_size):
t = threading.Thread(target = do_job, args = (i, pool_size))
t.setDaemon(True)
pool.append(t)
t.start()
while 1:
alive = False
for i in range(pool_size):
alive = alive or pool[i].isAlive()
if alive == True:
break
if not alive:
break
if __name__ == '__main__':
exited = False
main()
命令行運行
python signal_demo.py
截圖

參考文獻(xiàn)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python區(qū)塊鏈創(chuàng)建Block Class教程
這篇文章主要為大家介紹了Python區(qū)塊鏈創(chuàng)建Block Class教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
matplotlib命令與格式之tick坐標(biāo)軸日期格式(設(shè)置日期主副刻度)
這篇文章主要介紹了matplotlib命令與格式之tick坐標(biāo)軸日期格式(設(shè)置日期主副刻度),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
詳解django+django-celery+celery的整合實戰(zhàn)
這篇文章主要介紹了詳解django+django-celery+celery的整合實戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03

