併發/並行、進程/線程、線程調度

原文鏈接:https://baijiahao.baidu.com/s?id=1631225604668092175&wfr=spider&for=pc
併發與並行
  • 併發:指兩個或多個事件在同一個時間段內發生。
  • 並行:指兩個或多個事件在同一時刻發生(同時發生)。

在操作系統中,安裝了多個程序,併發指的是在一段時間內宏觀上有多個程序同時運行,這在單 CPU 系統中,每一時刻只能有一道程序執行,即微觀上這些程序是分時的交替運行,只不過是給人的感覺是同時運行,那是因爲分 時交替運行的時間是非常短的。 而在多個 CPU 系統中,則這些可以併發執行的程序便可以分配到多個處理器上(CPU),實現多任務並行執行, 即利用每個處理器來處理一個可以併發執行的程序,這樣多個程序便可以同時執行。目前電腦市場上說的多核 CPU,便是多核處理器,核越多,並行處理的程序越多,能大大的提高電腦運行的效率。

注意:單核處理器的計算機肯定是不能並行的處理多個任務的,只能是多個任務在單個 CPU 上併發運行。同理,線程也是一樣的,從宏觀角度上理解線程是並行運行的,但是從微觀角度上分析卻是串行運行的,即一個線程一個線程的去運行,當系統只有一個 CPU 時,線程會以某種順序執行多個線程,我們把這種情況稱之爲線程調度。

線程與進程

進程:是指一個內存中運行的應用程序,每個進程都有一個獨立的內存空間,一個應用程序可以同時運行多個進程;進程也是程序的一次執行過程,是系統運行程序的基本單位;系統運行一個程序即是一個進程從創建、運行到消亡的過程。

線程:線程是進程中的一個執行單元,負責當前進程中程序的執行,一個進程中至少有一個線程。一個進程中是可以有多個線程的,這個應用程序也可以稱之爲多線程程序。 簡而言之:一個程序運行後至少有一個進程,一個進程中可以包含多個線程。我們可以在電腦底部任務欄,右鍵----->打開任務管理器,可以查看當前任務的進程:

線程調度
  • 分時調度
    所有線程輪流使用 CPU 的使用權,平均分配每個線程佔用 CPU 的時間。

= 搶佔式調度
優先讓優先級高的線程使用 CPU,如果線程的優先級相同,那麼會隨機選擇一個(線程隨機性),Java 使用的爲搶佔式調度。

  • 設置線程的優先級

  • 搶佔式調度詳解
    大部分操作系統都支持多進程併發運行,現在的操作系統幾乎都支持同時運行多個程序。比如:一邊使用編輯器,一邊使用錄屏軟件,同時還開着畫圖板,dos 窗口等軟件。此時,這些程序是在同時運行,”感覺這些軟件好像在同一時刻運行着“。 實際上,CPU(中央處理器)使用搶佔式調度模式在多個線程間進行着高速的切換。對於 CPU 的一個核而言,某個時刻,只能執行一個線程,而 CPU 的在多個線程間切換速度相對我們的感覺要快,看上去就是在同一時刻運行。 其實,多線程程序並不能提高程序的運行速度,但能夠提高程序運行效率,讓 CPU 的 使用率更高。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章