1. 程式人生 > >python並發編程:多線程-線程理論

python並發編程:多線程-線程理論

流水線 控制 必須 一件事 工作 默認 ont size 定時

一 什麽是線程

  在傳統操作系統中,每個進程有一個地址空間,而且默認就有一個控制線程

  線程顧名思義,就是一條流水線工作的過程(流水線的工作需要電源,電源就相當於CPU),而一條流水線必須屬於一個車間,一個車間的工作過程是一個進程,車間負責把資源整合到一起,是一個資源單位,而一個車間內至少有一條流水線。

  

所以,進程只是用來把資源集中到一起(進程只是一個資源單位,或者說資源集合),而線程才是CPU上的執行單位。

  多新村(即多個控制線程)的概念時:在一個進程中存在多個線程,多個線程共享該進程的地址空間,相當於一個車間內有多條流水線,都共用一個車間的資源。例如:深圳地鐵和廣州地鐵是不同的進程,而深圳地鐵裏的2號線是一個線程,深圳地鐵所有的線路共享深圳地鐵所有的資源,比如所有的乘客可以被所有線路拉。

二 線程和進程的區別

1、同一個進程內的多個線程共享改進程內的地址資源
2、創建線程的開銷遠小於進程的開銷(創建一個進程,就是創建一個車間,涉及到申請空間,而且該空間內至少一條流水線,但創建線程,就只是一個車間內造一條流水線,無需申請空間,所以創建開銷小)

  

三 多線程應用舉例

  開啟一個字處理軟件進程,該進程肯定需要辦不止一件事情,比如監聽鍵盤輸入,處理文字,定時自動將文字保存到硬盤,這三個任務操作的都是同一塊數據,因而不能用多進程。只能在一個進程裏並發地開啟三個線程,如果是單線程,那就只能是,鍵盤輸入時,不能處理文字和自動保存,自動保存時又不能輸入和處理文字。

技術分享圖片

python並發編程:多線程-線程理論