1. 用函數創建多線程
在Python3中,Python提供了一個內置模塊 threading.Thread,可以很方便地讓我們創建多線程。
threading.Thread() 一般接收兩個參數:
線程函數名:要放置線程讓其后臺執行的函數,由我們自已定義,注意不要加();
線程函數的參數:線程函數名所需的參數,以元組的形式傳入。若不需要參數,可以不指定。
舉個例子
import time
from threading import Thread
# 自定義線程函數。
def target(name="Python"):
for i in range(2):
print("hello", name)
time.sleep(1)
# 創建線程01,不指定參數
thread_01 = Thread(target=target)
# 啟動線程01
thread_01.start()
# 創建線程02,指定參數,注意逗號
thread_02 = Thread(target=target, args=("MING",))
# 啟動線程02
thread_02.start()
可以看到輸出
hello Python
hello MING
hello Python
hello MING
2. 用類創建多線程
相比較函數而言,使用類創建線程,會比較麻煩一點。
首先,我們要自定義一個類,對于這個類有兩點要求,
必須繼承 threading.Thread 這個父類;
必須復寫 run 方法。
這里的 run 方法,和我們上面線程函數的性質是一樣的,可以寫我們的業務邏輯程序。在 start() 后將會調用。
來看一下例子 為了方便對比,run函數我復用上面的main。
import time
from threading import Thread
class MyThread(Thread):
def __init__(self, type="Python"):
# 注意:super().__init__() 必須寫
# 且最好寫在第一行
super().__init__()
self.type=type
def run(self):
for i in range(2):
print("hello", self.type)
time.sleep(1)
if __name__ == '__main__':
# 創建線程01,不指定參數
thread_01 = MyThread()
# 創建線程02,指定參數
thread_02 = MyThread("MING")
thread_01.start()
thread_02.start()
當然結果也是一樣的。
hello Python
hello MING
hello Python
hello MING
3. 線程對象的方法
上面介紹了當前 Python 中創建線程兩種主要方法。
創建線程是件很容易的事,但要想用好線程,還需要學習線程對象的幾個函數。
經過我的總結,大約常用的方法有如下這些:
# 如上所述,創建一個線程
t=Thread(target=func)
# 啟動子線程
t.start()
# 阻塞子線程,待子線程結束后,再往下執行
t.join()
# 判斷線程是否在執行狀態,在執行返回True,否則返回False
t.is_alive()
t.isAlive()
# 設置線程是否隨主線程退出而退出,默認為False
t.daemon = True
t.daemon = False
# 設置線程名
t.name = "My-Thread"
審核編輯:符乾江
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
多線程
+關注
關注
0文章
279瀏覽量
21025 -
python
+關注
關注
57文章
4876瀏覽量
90022
發布評論請先 登錄
相關推薦
熱點推薦
【瑞薩RA × Zephyr評測】多線程和看門狗
本文章旨在評估使用 Zephyr RTOS 在 Renesas FPB-RA6E2 開發板上實現多線程調度與硬件看門狗功能的應用。評估內容包括任務調度、看門狗初始化流程、主程序邏輯的詳細解析,以及實驗現象與數據分析。
解析Linux的進程、線程和協程
系統的穩定性和安全性。
(3)創建與銷毀:Linux使用fork()系統調用來創建新進程,通過exit()來終止進程。
線程(Thread)
線程是進程內的執行單元,多個
發表于 12-22 11:00
Linux多線程對比單線程的優勢
:「資源利用率」:通過多線程,可以更有效地利用CPU資源,特別是多核CPU。「并行處理」:線程允許同時執行多個任務,提高程序的執行效率。「簡化設計」:使用線程可以簡化程序設計,因為線程
發表于 12-01 06:11
用PLC實現卷徑計算的兩種算法
卷徑計算,是動態計算如鋼卷,紙卷等存料量的一種方法,它是實現張力控制和自動充放料、以及甩尾控制的重要前提。卷徑計算目前主流的方法有兩種,一種是根據機列速度(產線速度)和和被測卷的轉動角速度求得;另一種是根據被測卷的轉動圈數和測長
rt-thread studio 如何進行多線程編譯?
,使用的是5800h+32g內存+sn550 ssd,開啟16線程編譯時cpu的占用率也只能到30%,編譯完整個工程需要3分鐘
感覺多線程編譯設置沒有生效,有辦法提高編譯速度嗎
rtthread studio版本是 2.2.9
發表于 10-11 09:16
RT-Thread Nano移植后動態創建線程創建不了怎么解決?
RT-Thread Nano 移植后動態創建線程創建不了,靜態可以.直接燒錄DEMO也一樣,將RT_USING_HEAP開起來,使用動態創建就創建
發表于 09-19 06:28
rtth studio中nano 如何創建動態線程?
有沒有大佬,可以說一下為什么靜態線程可以正常使用,動態線程怎么也使用不了。 具體需要什么配置才能使用動態線程創建。謝謝!
發表于 09-11 06:01
【HZ-T536開發板免費體驗】—— linux創建線程
的執行任務成為單線程。多線程是程序中包含多個執行流,在一個程序中可以同時運行多個不同的線程來執行不同的任務。
多線程提高了CPU的使用鹵率。多線程
發表于 09-01 21:31
rtt studio中nano 如何創建動態線程?
有沒有大佬,可以說一下為什么靜態線程可以正常使用,動態線程怎么也使用不了。 具體需要什么配置才能使用動態線程創建。謝謝!
發表于 08-22 06:19
多線程的安全注意事項
多線程安全是指多個線程同時訪問或修改共享資源時,能夠保證程序的正確性和可靠性。
開發者選擇TaskPool或Worker進行多線程開發時,在TaskPool和Worker的工作線程中導
發表于 06-20 07:49
六相永磁同步電機串聯系統控制的兩種方法分析研究
/simulink環境下,分別用這兩種方法對兩臺電機串聯系統的運行特性進行仿真研究。當其中一臺電機轉速、負載變化時,分析兩種方法下另外一臺電機獨立運行的情況,臉證分析這兩種方法的可行性
發表于 06-10 13:09
一種實時多線程VSLAM框架vS-Graphs介紹
針對現有VSLAM系統語義表達不足、地圖可解釋性差的問題,本文提出vS-Graphs,一種實時多線程VSLAM框架。該方案顯著提升了重建地圖的語義豐富度、可解釋性及定位精度。實驗表明
請問如何在Python中實現多線程與多進程的協作?
大家好!我最近在開發一個Python項目時,需要同時處理多個任務,且每個任務需要不同的計算資源。我想通過多線程和多進程的組合來實現并發,但遇到了一些問題。
具體來說,我有兩個任務,一個是I/O密集型
發表于 03-11 06:57
創建了用于OpenVINO?推理的自定義C++和Python代碼,從C++代碼中獲得的結果與Python代碼不同是為什么?
創建了用于OpenVINO?推理的自定義 C++ 和 Python* 代碼。
在兩個推理過程中使用相同的圖像和模型。
從 C++ 代碼中獲得的結果與 Python* 代碼不同。
發表于 03-06 06:22
python創建多線程的兩種方法
評論