您好,登錄后才能下訂單哦!
這篇文章主要介紹了goroutine和coroutine的區別有哪些的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇goroutine和coroutine的區別有哪些文章都會有所收獲,下面我們一起來看看吧。
區別:1、goroutine通過通道來通信,coroutine通過讓出和恢復操作來通信。2、goroutine協程間不完全同步,可以利用多核并行運行;coroutine協程間完全同步,不會并行。3、goroutine可在多個協程/線程上切換;coroutine在一個線程中運行。4、應用程序長時間大量地占用CPU,goroutine中用戶有權終止這個任務,coroutine不行。
C#、Lua、Python 語言都支持 coroutine 特性。coroutine 與 goroutine 在名字上類似,都可以將函數或者語句在獨立的環境中運行,但是它們之間有兩點不同:
goroutine 可能發生并行執行;
但 coroutine 始終順序執行。
goroutines 意味著并行(或者可以以并行的方式部署),coroutines 一般來說不是這樣的,goroutines 通過通道來通信;coroutines 通過讓出和恢復操作來通信,goroutines 比 coroutines 更強大,也很容易從 coroutines 的邏輯復用到 goroutines。
狹義地說,goroutine 可能發生在多線程環境下,goroutine 無法控制自己獲取高優先度支持;coroutine 始終發生在單線程,coroutine 程序需要主動交出控制權,宿主才能獲得控制權并將控制權交給其他 coroutine。
goroutine 間使用 channel 通信,coroutine 使用 yield 和 resume 操作。
goroutine 和 coroutine 的概念和運行機制都是脫胎于早期的操作系統。
coroutine 的運行機制屬于協作式任務處理,早期的操作系統要求每一個應用必須遵守操作系統的任務處理規則,應用程序在不需要使用 CPU 時,會主動交出 CPU 使用權。如果開發者無意間或者故意讓應用程序長時間占用 CPU,操作系統也無能為力,表現出來的效果就是計算機很容易失去響應或者死機。
goroutine 屬于搶占式任務處理,已經和現有的多線程和多進程任務處理非常類似。應用程序對 CPU 的控制最終還需要由操作系統來管理,操作系統如果發現一個應用程序長時間大量地占用 CPU,那么用戶有權終止這個任務。
coroutine和goroutine的區別總結
區別一:
goroutine 通過通道來通信;
coroutine通過讓出和恢復操作來通信
區別二:
goroutine協程間不完全同步,可以利用多核并行運行,具體要看channel的設計;
coroutine協程間完全同步,不會并行
區別三:
goroutine可以在多個協程在多個線程上切換,既可以用到多核,又可以減少切換開銷。
coroutine只在一個線程中運行,只在一個線程中運行
區別四:
goroutine操作系統如果發現一個應用程序長時間大量地占用 CPU,那么用戶有權終止這個任務。
coroutine如果開發者無意間或者故意讓應用程序長時間占用 CPU,操作系統也無能為力,表現出來的效果就是計算機很容易失去響應或者死機。
關于“goroutine和coroutine的區別有哪些”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“goroutine和coroutine的區別有哪些”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。