網站首頁 編程語言 正文
一、什么是線程?
我們知道工人都是同時在工廠工作,復制各自的工作的。他們就是一個一個獨立運行的單位!
線程也是類似這樣的一個獨立的運行單位,多線程,就是多個獨立的運行單位,同時執行同樣的事情。
簡單這樣理解,后面會進行對比。
threading.Thread
類是Python
中的線程類,它封裝了線程的信息和一些同用的方法。
線程有狀態,拿工人一天的狀態來比喻很合適,早上上班,然后工作,有時候需要停下來休息,最后下班。
運行下面的代碼看看:
import threading mythread = threading.Thread() print("mythread:", mythread) print("is_alive:", mythread.is_alive()) mythread.start() print("mythread:", mythread) print("is_alive:", mythread.is_alive())
下面是運行結果:
建議讀者先運行一下。
二、再來解釋線程的代碼
上面我們使用了threading
這個庫,然后創建Thread類的對象實例,賦值給mythread變量。
接著打印了對象和線程對象的一個函數is_alive()
是否活躍狀態。
兩次都是False
但是第二次我們看到線程對象打印出來變成‘stopped
’.
也就是說我們跑完了start
函數(該函數為線程啟動函數)之后,線程就進入stopped
狀態了。
上面那個就是線程,可是貌似啥也沒做,我們下面讓它做點事情唄。
三、線程觸發業務函數,線程調用業務函數
比如這次的業務是:
def dianzan_guanzhu(): ? ? now = datetime.datetime.now() #初始化時間變量 ? ? name = "python萌新" ? ? print("%s name:%s" % (now, name)) #第一次打印時間和粉絲名字 ? ? time.sleep(1) ? ? result = "好棒!" + name + " 關注雷學委,白嫖了好多知識和開發經驗!" ? ? print("%s result:%s" % (now, result)) #第二次打印時間和粉絲活動 ? ? return result
我們可以使用線程來調用。下面學委寫了一個帶參數的函數。 通過線程調用業務函數的時候指定:
- target:設置為即將被調用的函數
- kwargs: 如果有參數,直接通過傳遞一個k-v dict即可。
def dianzan_guanzhu(name): ? ? #省略一些代碼 mythread = threading.Thread(target=dianzan_guanzhu, kwargs={"name": "python萌新"})
好下面,編寫全部代碼,使用線程來點贊,和直接調用
我們看看下面的代碼:
import threading import datetime import time """學委定義了一個關注函數""" def dianzan_guanzhu(): ? ? now = datetime.datetime.now() ? ? name = "python萌新" ? ? print("%s name:%s" % (now, name)) ? ? time.sleep(1) ? ? result = "好棒!" + name + " 關注雷學委,學到了好多知識和開發經驗!" ? ? print("%s result:%s" % (now, result)) ? ? return result mythread = threading.Thread(target=dianzan_guanzhu) print("mythread:", mythread) print("is_alive:", mythread.is_alive()) mythread.start() print("mythread:", mythread) print("is_alive:", mythread.is_alive()) dianzan_guanzhu() print("is_alive:", mythread.is_alive())
直接復制運行,這里我們這個dianzan_guanzhu
函數被調用了兩次
第一次是mythread.start
函數。
第二次是我們直接脫離線程調用dianzan_guanzhu
函數。
下面是運行結果:
好像沒啥的樣子。
再看一次,注意關注每次打印的時間,輸入的時間好像錯亂了?沒錯,不是眼花,是正確運行結果。
因為進入dianzan_guanzhu
函數之后,初始化了now變量,這個時間固定了。
但是在線程外面也調用dianzan_guanzhu
函數,所以這里是:兩個線程在同時做同樣的事情。
四、多了一個線程是哪個?
這里補充一下,我們寫python腳本,運行代碼的時候,本身是在一個主線程中的。
只是之前一直沒解除線程概念,沒寫多線程程序,沒有感知到這事情。
從現在開始,你要清楚知道:每個程序運行都有一個主線程。
回到結果,兩個線程先后依次調用通過函數:
- 首先,先后依次打印第一行輸出。
- 分開休眠了一秒(sleep(1))。
- 最后,先后依次打印第二行輸出。
五、總結
我們先把線程的基礎知識搞懂。
- 每個程序運行過程中至少有一個主線程
- 需要啟動更多線程使用
Thread
類來做,target
參數用來綁定業務函數。啟動線程用start函數。
原文鏈接:https://levin.blog.csdn.net/article/details/121847002
相關推薦
- 2023-05-06 MacOS安裝python報錯"zsh:?command?not?found:python"的解決方
- 2022-03-03 解決Warning: [antdv: LocaleProvider] `LocaleProvider
- 2022-10-14 Springboot整合Netty提供WebSocket服務
- 2023-01-02 Kotlin?LinearLayout與RelativeLayout布局使用詳解_Android
- 2022-05-11 解決 IntelliJ IDEA 中 .propertise 文件保存后中文亂碼
- 2022-12-25 一文帶你熟悉Go語言中的for循環_Golang
- 2022-12-04 python?使用enumerate()函數詳解_python
- 2022-02-28 Error: A <Route> is only ever to be used as the ch
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支