App下載

能否解釋下什么是進(jìn)程、線程、協(xié)程,他們之間的關(guān)系是怎樣的?

享受養(yǎng)生的年輕人 2021-12-15 14:24:51 瀏覽數(shù) (2546)
反饋

進(jìn)程: 本質(zhì)上是一個獨(dú)立執(zhí)行的程序,進(jìn)程是操作系統(tǒng)進(jìn)行資源分配和調(diào)度的基本概念,操作系統(tǒng)進(jìn)行資源分配和調(diào)度的一個獨(dú)立單位。


線程: 是操作系統(tǒng)能夠進(jìn)行運(yùn)算調(diào)度的最小單位。它被包含在進(jìn)程之中,是進(jìn)程中的實際運(yùn)作單位。一個進(jìn)程中可以并發(fā)多個線程,每條線程執(zhí)行不同的任務(wù),切換受系統(tǒng)控制。


協(xié)程:  又稱為微線程,是一種用戶態(tài)的輕量級線程,協(xié)程不像線程和進(jìn)程需要進(jìn)行系統(tǒng)內(nèi)核上的上下文切換,協(xié)程的上下文切換是由用戶自己決定的,有自己的上下文,所以說是輕量級的線程,也稱之為用戶級別的線程就叫協(xié)程,一個線程可以多個協(xié)程,線程進(jìn)程都是同步機(jī)制,而協(xié)程則是異步Java的原生語法中并沒有實現(xiàn)協(xié)程,目前python、Lua和GO等語言支持。


關(guān)系:一個進(jìn)程可以有多個線程,它允許計算機(jī)同時運(yùn)行兩個或多個程序。線程是進(jìn)程的最小執(zhí)行單位,CPU
的調(diào)度切換的是進(jìn)程和線程,進(jìn)程和線程多了之后調(diào)度會消耗大量的CPU,CPU上真正運(yùn)行的是線程,線程可
以對應(yīng)多個協(xié)程。


協(xié)程對于多線程有什么優(yōu)缺點(diǎn)嗎?

優(yōu)點(diǎn):
非常快速的上下文切換,不用系統(tǒng)內(nèi)核的上下文切換,減小開銷。
單線程即可實現(xiàn)高并發(fā),單核CPU可以支持上萬的協(xié)程。
由于只有一個線程,也不存在同時寫變量的沖突,在協(xié)程中控制共享資源不需要加鎖。


缺點(diǎn):
協(xié)程無法利用多核資源,本質(zhì)也是個單線程。
協(xié)程需要和進(jìn)程配合才能運(yùn)行在多CPU上。
目前java沒成熟的第三方庫,存在風(fēng)險。
調(diào)試debug存在難度,不利于發(fā)現(xiàn)問題。


0 人點(diǎn)贊