這個類表示在單獨的控制線程中運行的活動。有兩種方法可以指定這種活動,給構造函數傳遞迴調對象,或者在子類中重寫run() 方法。其他方法(除了構造函數)都不應在子類中被重寫。換句話說,在子類中只有__init__()和run()方法被重寫。 一旦線程對象被創建,它的活動需要通過調用線程的start() ...
這個類表示在單獨的控制線程中運行的活動。有兩種方法可以指定這種活動,給構造函數傳遞迴調對象,或者在子類中重寫run() 方法。其他方法(除了構造函數)都不應在子類中被重寫。換句話說,在子類中只有__init__()和run()方法被重寫。
一旦線程對象被創建,它的活動需要通過調用線程的start()方法來啟動。這方法再調用控制線程中的run方法。
一旦線程被激活,則這線程被認為是'alive'(活動)。當它的run()方法終止時-正常退出或拋出未處理的異常,則活動狀態停止。isAlive()方法測試線程是否是活動的。
一個線程能調用別的線程的join()方法。這將阻塞調用線程,直到擁有join()方法的線程的調用終止。
線程有名字。名字能傳給構造函數,通過setName()方法設置,用getName()方法獲取。
線程能被標識為'daemon thread'(守護線程).這標誌的特點是當剩下的全是守護線程時,則Python程式退出。它的初始值繼承於創建線程。這標誌用setDaemon()方法設置,用isDaemon()獲取。
存在'main thread'(主線程),它對應於Python程式的初始控制線程。它不是後臺線程。
有可能存在'dummy thread objects'(啞線程對象)被創建。這些線程對應於'alien threads'(外部線程),它們在Python的線程模型之外被啟動,像直接從C語言代碼中啟動。啞線程對象只有有限的功能,它們總是被認為是活動的,守護線程,不能使用join()方法。它們從不能被刪除,既然它無法監測到外部線程的中止。
- class Thread(group=None, target=None, name=None, args=(), kwargs={})
-
構造函數能帶有關鍵字參數被調用。這些參數是:
group 應當為 None,為將來實現ThreadGroup類的擴展而保留。
target 是被 run()方法調用的回調對象. 預設應為None, 意味著沒有對象被調用。
name 為線程名字。預設,形式為'Thread-N'的唯一的名字被創建,其中N 是比較小的十進位數。
args是目標調用參數的tuple,預設為()。
kwargs是目標調用的參數的關鍵字dictionary,預設為{}。
如果子線程重寫了構造函數,它應保證調用基類的構造函數(Thread.__init__()),線上程中進行其他工作之前。
- start()
- 啟動線程活動。
在每個線程對象中最多被調用一次。它安排對象的run() 被調用在一單獨的控制線程中。
run()
- 用以表示線程活動的方法。
-
你可能在子類重寫這方法。標準的 run()方法調用作為target傳遞給對象構造函數的回調對象。如果存在參數,一系列關鍵字參數從args和kwargs參數相應地起作用。
- join([timeout])
- 等待至線程中止。這阻塞調用線程直至線程的join() 方法被調用中止-正常退出或者拋出未處理的異常-或者是可選的超時發生。
-
當timeout參數未被設置或者不是
None
,它應當是浮點數指明以秒計的操作超時值。因為join()總是返回None
,你必須調用isAlive()來判別超時是否發生。 -
當timeout 參數沒有被指定或者是
None
時,操作將被阻塞直至線程中止。 -
線程能被join()許多次。
-
線程不能調用自身的join(),因為這將會引起死鎖。
-
線上程啟動之前嘗試調用join()會發生錯誤。
- getName()
- 返回線程名。
- setName(name)
- 設置線程名。
-
這名字是只用來進行標識目的的字元串。它沒有其他作用。多個線程可以取同一名字。最初的名字通過構造函數設置。
- isAlive()
- 返回線程是否活動的。
-
大致上,線程從 start()調用開始那點至它的run()方法中止返回時,都被認為是活動的。模塊函數enumerate()返回活動線程的列表。
- isDaemon()
- 返回線程的守護線程標誌。
- setDaemon(daemonic)
- 設置守護線程標誌為布爾值daemonic。它必須在start()調用之前被調用。
-
初始值繼承至創建線程。
-
當沒有活動的非守護線程時,整個Python程式退出。