国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

解決python父線程關閉后子線程不關閉問題

瀏覽:61日期:2022-07-27 15:02:27

我們都知道,python可以通過threading module來創建新的線程,然而在創建線程的線程(父線程)關閉之后,相應的子線程可能卻沒有關閉,這可能是因為代碼中沒有使用setDaemon(True)函數。

接下來,使用一個例子來說明:

import threadingdef prt_hello() : while 1 : print ’hello’if __name__ == ’__main__’ : t = threading.Thread(target=prt_hello) t.setDaemon(True) t.start()

我們需要把setDaemon函數放在start函數前面,不然它是不給通過的,并且返回’cannot set daemon status of active thread‘

補充知識:Python 多線程的退出/停止的一種是實現思路

在使用多線程的過程中,我們知道,python的線程是沒有stop/terminate方法的,也就是說它被啟動后,你無法再主動去退出它,除非主進程退出了,注意,是主進程,不是線程的父進程.

一個比較合理的方式就是把原因需要放到threading.Thread的target中的線程函數,改寫到一個繼承類中,下面是一個實現例子

import threadingimport timeimport os # 原本需要用來啟動的無線循環的函數def print_thread(): pid = os.getpid() counts = 0 while True: print(f’threading pid: {pid} ran: {counts:04d} s’) counts += 1 time.sleep(1) # 把函數放到改寫到類的run方法中,便可以通過調用類方法,實現線程的終止class StoppableThread(threading.Thread): def __init__(self, daemon=None): super(StoppableThread, self).__init__(daemon=daemon) self.__is_running = True self.daemon = daemon def terminate(self): self.__is_running = False def run(self): pid = os.getpid() counts = 0 while self.__is_running: print(f’threading running: {pid} ran: {counts:04d} s’) counts += 1 time.sleep(1) def call_thread(): thread = StoppableThread() thread.daemon = True thread.start() pid = os.getpid() counts = 0 for i in range(5): print(f’0 call threading pid: {pid} ran: {counts:04d} s’) counts += 2 time.sleep(2) # 主動把線程退出 thread.terminate() if __name__ == ’__main__’: call_thread() print(f’==========call_thread finish===========’) counts = 0 for i in range(5): counts += 1 time.sleep(1) print(f’main thread:{counts:04d} s’)

以上這篇解決python父線程關閉后子線程不關閉問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 中西区| 淮阳县| 涪陵区| 临夏市| 望都县| 扶绥县| 德惠市| 乡城县| 安庆市| 治县。| 贵德县| 镇巴县| 哈密市| 阿巴嘎旗| 青岛市| 内黄县| 乡宁县| 沁水县| 富源县| 普宁市| 赤峰市| 青海省| 淮南市| 黄冈市| 永靖县| 仲巴县| 湘西| 余干县| 云阳县| 华池县| 罗城| 洪雅县| 荥经县| 漳州市| 辽阳县| 卓资县| 扬州市| 抚远县| 乡城县| 延川县| 平顺县|