⑴ python 在線程函數中如何實現線程的暫停、恢復和終止
我們都知道python中可以是threading模塊實現多線程, 但是模塊並沒有提供暫停, 恢復和停止線程的方法, 一旦線程對象調用start方法後, 只能等到對應的方法函數運行完畢. 也就是說一旦start後, 線程就屬於失控狀態. 不過, 我們可以自己實現這些. 一般的方法就是循環地判斷一個標志位, 一旦標志位到達到預定的值, 就退出循環. 這樣就能做到退出線程了. 但暫停和恢復線程就有點難了, 我一直也不清除有什麼好的方法
⑵ 如何控制python多線程的退出
一般來說,多線程模式下,建議主線程只處理線程本身的調度,不去處理具體業務。通常在創建線程後,join等待所有線程退出。
就題主的問題,可以創建線程一、二之後,主線程等待線程一退出,之後用sys.exit退出。
但是,線程二死循環的做法不是好習慣,用系統退出的方式,很可能造成循環內部的事務中斷,建議改成條件循環,檢查某個對象的數據,滿足後退出循環。
這樣,可以在主線程等待線程一、線程二退出,保證事務完整性。
⑶ python多線程退出
這種情況很正常,Python自身的線程並不安全且不與PyQt兼容,你既然用PyQt了,為什麼不嘗試用Qt自身的線程類QThread呢?那麼基於Qt自身的特點,主線程關閉時,子線程就可以安全地退出了,而不會出現你現在這種情況了。
⑷ python如何讓後台線程執行必要的操作後再退出
可以設置加鎖的全局變數等於你的線程數,在線程運行的最後這個變數減一,然後起線程的程序判斷這個變數值為0了就可以下次循環
⑸ python pyqt5在使用多線程時自動退出是怎麼回事
線程只執行一次……讓我來猜一猜。
你可能會認為創建一個線程去執行某個動作就完事了?
一段代碼不管是在主線程里還是在新建的線程里,它都是按代碼本身的規則那麼執行的,該循環就循環,該結束就結束。
所以,我們建立一個線程去執行某個動作,主要就是讓這個動作的執行不影響主程的執行,不要因為它導致主程序的某環節等待這個動作的結果。
舉例來說,一個定時3秒去讀一下某個文件,總不能做個循環,讀一下文件,然後sleep3秒吧,那除了這個,什麼也幹不了,基本都是在【等待3秒】這里耗著了。解決辦法就是做個線程去完成【讀某個文件】,然後這個事完了之後、前再建一個同樣的線程讓它三秒後執行。
看下圖:
這個sort_loop就是這樣乾的:
【紅框2】就是主要的工作內容(對self.data進行收縮)
如果簡簡單單的就這,那它就執行一次就完事了,哪怕你把sort_loop放到新線程里,也是一樣。
要在sort_loop里再新建一個線程,新線程還是執行sort_loop,於是就是這樣的:
A把桌子擦了擦,把抹布塞給了B;
B把桌子擦了擦,把抹布塞給了C;
C把桌子擦了擦,把抹布塞給了D...
這才構成一個線程循環。
⑹ Python主線程結束為什麼守護線程還在運行
法很多。通常的法是,子線程出異常後,主進程檢查到它的狀態不正常,然後自己主動將其餘線程退出,最後自己再退出。這是穩妥的法。另外的法是,某一個子線程專用於監控狀態。它發現狀態不對時,直接強制進程退出。法1,發消息給主進程,讓主進程退出。法2:用kill,pskill等方法,直接按進程PID殺進程。
⑺ 如何控制和關閉python 線程
辦法很多。通常的辦法是,子線程出異常後,主進程檢查到它的狀態不正常,然後自己主動將其餘線程退出,最後自己再退出。這是穩妥的辦法。
另外的辦法是,某一個子線程專用於監控狀態。它發現狀態不對時,直接強制進程退出。辦法1,發消息給主進程,讓主進程退出。辦法2:用kill,
pskill等方法,直接按進程pid殺進程。
⑻ python程序運行結束後,怎麼讓它自動回到開頭重新運行
1、首先在電腦的搜索框中輸入「idle」,出現的「IDLE」就是Python的入口,如下圖所示。
⑼ 線程停止 python
簡單來說,它kill的原理是設置一個flag位,然後線程在執行下一句python語句檢測到這個位被設置了之後,就會自行退出,以達到kill的目的。 另外還有一種更容易理解的flag置位的實現方式:classKillableThread(threading.Thread):def__init__(self):threading.Thread. __init__(self)self.stop = Falsedefrun(self):whilenotself.stop:somefunction() 這種方式相比第一種而言,又有一點不足:kill生效的時限,最大等於somefunction執行一遍所花的時間。 而第一種方式,在下一句python語句執行時就會生效。 不過可以料想,第一種實現方式,整體的執行效率會慢一點。
⑽ python 線程結束之後怎麼再重新啟動
給出一個簡單的線程互斥的例子,例子中同時啟動兩個線程,a線程獲取鎖,獲取後b線程處於等待狀態,只有a線程釋放鎖,才能進入b線程。代碼如下:
import threading
import time
def hello(name):
print(name + ' started')
lock.acquire(True)
time.sleep(50)
print(name + ' running')
lock.release()
print(name + ' exit')
lock = threading.Lock()
a = threading.Thread(target=hello,args='a')
b = threading.Thread(target=hello,args='b')
a.start()
b.start()