Python多任务(1.多任务的介绍、并发和并行概念及小例子)
目錄
1.多任務的概念
2.單核CPU是怎么解決多任務的?
3.多任務的執行方式:并發和并行
?4.單任務的執行例子:
5.多任務的執行例子:
1.多任務的概念
? ? 簡單地說,就是操作系統可以同一時間執行多個任務
? ? 在代碼里面,就是一個程序有多個地方同時執行
? ? 打個比方,你一邊用著這瀏覽器上網,一邊在聽MP3,一邊在用Word趕作業,這就是多任務
2.單核CPU是怎么解決多任務的?
? ?單核:意味著同一時刻只能執行一件事情
? ?操作系統輪流讓各任務交替執行,任務1執行0.01秒,切換到任務2,任務2執行0.01,再切換到任務3,
? ? 執行0.01秒。。。。。這樣反復的執行下去,每個任務都是交替執行的,但是由于CPU的執行速度實在是太快了,
? ? 我們感覺就像是所有任務都在同時執行一樣,這就是所謂的 “時間片輪轉”? 。
3.多任務的執行方式:并發和并行
? ? 并行: 真的多任務? ? ?(CPU的核數大于任務數量)
? ? 并發:? 假的多任務? ? ?(CPU的核數小于任務數量)
? ?真正的并行執行多任務只能在多核CPU上實現,但是,由于任務數量遠遠多于CPU的核心數量,所以,操作系統也會自動? ? ? 把很多任務輪流調度到每個核心上執行。
?4.單任務的執行例子:
import timedef sing():"""唱歌5秒鐘"""for i in range(5):print("---正在唱唱歌---")time.sleep(1)def dance():"""跳舞5秒鐘"""for i in range(5):print("---正在唱跳舞---")time.sleep(1)def main():sing()dance()if __name__ == '__main__':main()? 運行的結果為:? ? ? 先把唱歌執行完花費5秒鐘,? 再花費5秒鐘執行完跳舞,? 一共花費10秒鐘
? ? ? ??
5.多任務的執行例子:
import time import threadingdef sing():"""唱歌5秒鐘"""for i in range(5):print("---正在唱唱歌---")time.sleep(1)def dance():"""跳舞5秒鐘"""for i in range(5):print("---正在唱跳舞---")time.sleep(1)def main():t1 = threading.Thread(target=sing)t2 = threading.Thread(target=dance)t1.start()t2.start()if __name__ == '__main__':main()執行結果:? 唱歌和跳舞同步執行,執行一次花費1秒,所以一共執行花費5秒鐘。
總結
以上是生活随笔為你收集整理的Python多任务(1.多任务的介绍、并发和并行概念及小例子)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python可视化中的Matplotli
- 下一篇: Python多任务(2.线程的概念以及组