python退出線程
① 如何控制和關閉python 線程
一般來說,多線程模式下,建議主線程只處理線程本身的調度,不去處理具體業務。通常在創建線程後,join等待所有線程退出。 就題主的問題,可以創建線程一、二之後,主線程等待線程一退出,之後用sys.exit退出。
② Python 多線程爬蟲如何優雅的退出
一般來說,多線程模式下,建議主線程只處理線程本身的調度,不去處理具體業務。通常在創建線程後,join等待所有線程退出。 就題主的問題,可以創建線程一、二之後,主線程等待線程一退出,之後用sys.exit退出。
③ python多線程退出
這種情況很正常,Python自身的線程並不安全且不與PyQt兼容,你既然用PyQt了,為什麼不嘗試用Qt自身的線程類QThread呢?那麼基於Qt自身的特點,主線程關閉時,子線程就可以安全地退出了,而不會出現你現在這種情況了。
④ python pyqt5在使用多線程時自動退出是怎麼回事
線程只執行一次……讓我來猜一猜。
你可能會認為創建一個線程去執行某個動作就完事了?
一段代碼不管是在主線程里還是在新建的線程里,它都是按代碼本身的規則那麼執行的,該循環就循環,該結束就結束。
所以,我們建立一個線程去執行某個動作,主要就是讓這個動作的執行不影響主程的執行,不要因為它導致主程序的某環節等待這個動作的結果。
舉例來說,一個定時3秒去讀一下某個文件,總不能做個循環,讀一下文件,然後sleep3秒吧,那除了這個,什麼也幹不了,基本都是在【等待3秒】這里耗著了。解決辦法就是做個線程去完成【讀某個文件】,然後這個事完了之後、前再建一個同樣的線程讓它三秒後執行。
看下圖:
這個sort_loop就是這樣乾的:
【紅框2】就是主要的工作內容(對self.data進行收縮)
如果簡簡單單的就這,那它就執行一次就完事了,哪怕你把sort_loop放到新線程里,也是一樣。
要在sort_loop里再新建一個線程,新線程還是執行sort_loop,於是就是這樣的:
A把桌子擦了擦,把抹布塞給了B;
B把桌子擦了擦,把抹布塞給了C;
C把桌子擦了擦,把抹布塞給了D...
這才構成一個線程循環。
⑤ Python里如何終止一個線程
Python用sleep停止一個線程的運行,而不影響主線程的運行,案例代碼如下:
fromthreadingimport*
importtime
classMyThread(Thread):
defrun(self):
self.ifdo=True;
whileself.ifdo:
print'Iamrunning...'
time.sleep(2)
defstop(self):
print'Iamstoppingit...'
self.ifdo=False;
tr=MyThread()
tr.setDaemon(True)
tr.start()
print'Iwillstopit...'
time.sleep(5)
tr.stop()
tr.join()
⑥ python theading 如何結束線程
其實時,如果主線程退出的話,其它子線程就可退出。
如果你要某些線程在運行一個閥值自動退出,你可以在線程裡面做一步運行時間檢測(或者循環次數檢測)。
⑦ Python中怎麼在終止一個線程的同時終止另外一個線程
設置一個全局變數,初值為False
設置鍵盤監聽事件,當監測到特定按鍵時,將全局變數的值修改為True
在每個子線程中,循環檢測全局變數的值,當檢測到值為True時退出線程函數。
⑧ 如何控制python多線程的退出
一般來說,多線程模式下,建議主線程只處理線程本身的調度,不去處理具體業務。通常在創建線程後,join等待所有線程退出。
就題主的問題,可以創建線程一、二之後,主線程等待線程一退出,之後用sys.exit退出。
但是,線程二死循環的做法不是好習慣,用系統退出的方式,很可能造成循環內部的事務中斷,建議改成條件循環,檢查某個對象的數據,滿足後退出循環。
這樣,可以在主線程等待線程一、線程二退出,保證事務完整性。
⑨ python 在線程函數中如何實現線程的暫停、恢復和終止
我們都知道python中可以是threading模塊實現多線程, 但是模塊並沒有提供暫停, 恢復和停止線程的方法, 一旦線程對象調用start方法後, 只能等到對應的方法函數運行完畢. 也就是說一旦start後, 線程就屬於失控狀態. 不過, 我們可以自己實現這些. 一般的方法就是循環地判斷一個標志位, 一旦標志位到達到預定的值, 就退出循環. 這樣就能做到退出線程了. 但暫停和恢復線程就有點難了, 我一直也不清除有什麼好的方法
⑩ Python 如何強制關閉線程
Python用sleep停止一個線程的運行,而不影響主線程的運行,案例代碼如下:
from threading import *import time class MyThread(Thread): def run (self): self.ifdo = True; while self.ifdo: print 'I am running...' time.sleep(2) def stop (self): print 'I am stopping it...' self.ifdo = False; tr = MyThread()tr.setDaemon(True)tr.start()print 'I will stop it...'time.sleep(5)tr.stop()tr.join()