欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文了解Go 并發(fā)與并行

 更新時間:2024年05月15日 10:12:18   作者:比豬聰明  
并發(fā)性和并行性是是兩個既有聯(lián)系又有所區(qū)別的概念,本文主要介紹了Go并發(fā)與并行,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

Go語言,由Google的Robert Griesemer、Rob Pike和Ken Thompson于2009年開發(fā),是一種靜態(tài)類型、垃圾回收、多線程并發(fā)的編程語言。Go語言的設(shè)計目標是簡單、高效、易于使用。它的并發(fā)模型非常強大,可以輕松地處理大量并發(fā)任務(wù),這使得Go語言成為現(xiàn)代高性能并發(fā)應(yīng)用的理想選擇。

在Go語言(Golang)中,并發(fā)(Concurrency)和并行(Parallelism)是兩個既有聯(lián)系又有所區(qū)別的概念

并發(fā)(Concurrency)

并發(fā)指的是在一段時間內(nèi),多個任務(wù)能夠開始、執(zhí)行和完成,這些任務(wù)在宏觀上看起來是同時進行的,盡管在微觀層面上它們可能并不是真正的同時執(zhí)行。Go語言通過goroutines(輕量級線程)和channels(用于goroutines間通信的安全通道)來支持高效率的并發(fā)編程。并發(fā)的重點在于任務(wù)的組織和管理,使得即使在單個CPU核心上,也能通過時間切片和任務(wù)調(diào)度,給予用戶多個任務(wù)同時進行的錯覺。

并行(Parallelism)

并行則是指在物理上或邏輯上的多個處理器(或多核CPU)同時執(zhí)行多個任務(wù)。當程序能夠充分利用多核處理器的多個核心,使得不同的任務(wù)或任務(wù)的部分確實同時在不同的處理器上執(zhí)行,這就是并行。Go語言的運行時能夠自動利用多核處理器,使得當有足夠的goroutines需要運行時,它們可以被分配到不同的CPU核心上并行執(zhí)行,從而提升程序的執(zhí)行效率。

goroutine的實現(xiàn)原理

goroutine的實現(xiàn)原理主要依賴于Go語言的運行時(runtime)和調(diào)度器(scheduler)。當我們創(chuàng)建一個goroutine時,運行時會為其分配一個獨立的??臻g,并將其加入到調(diào)度器的運行隊列中。調(diào)度器會根據(jù)goroutine的優(yōu)先級和狀態(tài)(運行、休眠、阻塞等)來調(diào)度它們的執(zhí)行。

channel的實現(xiàn)原理

channel的實現(xiàn)原理主要依賴于Go語言的運行時和內(nèi)存模型。當我們創(chuàng)建一個channel時,運行時會為其分配一個緩沖區(qū),用于存儲數(shù)據(jù)。channel的讀寫操作是原子的,這意味著它們不會被中斷。當一個goroutine向channel中寫入數(shù)據(jù)時,運行時會將數(shù)據(jù)放入緩沖區(qū),并通知其他goroutine。當一個goroutine從channel中讀取數(shù)據(jù)時,運行時會從緩沖區(qū)中取出數(shù)據(jù),并通知其他goroutine。

關(guān)系與區(qū)別

  • 區(qū)別:并發(fā)關(guān)注的是任務(wù)的執(zhí)行方式和任務(wù)間的協(xié)作,能夠在單核或多核環(huán)境下工作,不保證任務(wù)絕對同時執(zhí)行。而并行關(guān)注的是任務(wù)的實際同時執(zhí)行,需要多核環(huán)境來實現(xiàn)。
  • 聯(lián)系:并發(fā)是并行的基礎(chǔ),沒有并發(fā)就沒有并行。并發(fā)使得程序能夠在邏輯上分解為多個獨立執(zhí)行的單元,而并行則是在硬件層面實現(xiàn)這些單元的同時執(zhí)行,從而達到更高的性能。 
for i := 1; i <= 10; i++ {

	go func() {
		fmt.Println("123")
	}()
}

 這段代碼展示了Go語言中并發(fā)的特性。for循環(huán)與通過go關(guān)鍵字啟動的goroutines之間是并發(fā)執(zhí)行的。具體分析如下:

  • 并發(fā)性: 當for循環(huán)每次迭代時,它都會啟動一個新的goroutine并通過go func() {...}()表達式。這意味著循環(huán)繼續(xù)進行下一次迭代時,剛啟動的goroutine幾乎立刻開始執(zhí)行,無需等待前一個goroutine完成。因此,這些goroutine的執(zhí)行是并發(fā)的——它們的執(zhí)行在時間上重疊,不過實際的執(zhí)行順序取決于Go運行時的調(diào)度策略和可用的處理器核心。

  • 并行性: 是否并行執(zhí)行(即是否同時在多個處理器核心上執(zhí)行)則取決于運行時環(huán)境和當前系統(tǒng)的負載。如果系統(tǒng)有多個處理器核心且goroutines的數(shù)量足夠多以至于它們不能全部在一個核心上高效執(zhí)行,Go的調(diào)度器可能會將這些goroutine分布在不同的核心上并行執(zhí)行。然而,對于這段特定的代碼,由于goroutine內(nèi)的工作非常輕(僅打印一個空字符串),并行收益不大,甚至可能全部在一個核心上順序快速執(zhí)行完,因為啟動goroutine和打印操作都非常快。

總結(jié)來說,這段代碼展示了并發(fā)執(zhí)行,而并行性取決于運行時的具體情況,但就這個簡單的示例而言,并行效果可能不明顯。

到此這篇關(guān)于一文了解Go 并發(fā)與并行的文章就介紹到這了,更多相關(guān)Go 并發(fā)與并行內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入解析Sync.Pool如何提升Go程序性能

    深入解析Sync.Pool如何提升Go程序性能

    在并發(fā)編程中,資源的分配和回收是一個很重要的問題。Go?語言的?Sync.Pool?是一個可以幫助我們優(yōu)化這個問題的工具。本篇文章將會介紹?Sync.Pool?的用法、原理以及如何在項目中正確使用它,希望對大家有所幫助
    2023-05-05
  • go 異常處理panic和recover的簡單實踐

    go 異常處理panic和recover的簡單實踐

    在Go語言中,異常處理主要通過panic和recover這兩個內(nèi)建函數(shù)來實現(xiàn),本文主要介紹了go異常處理panic和recover的簡單實踐,具有一定的參考價值,感興趣的可以了解一下
    2025-04-04
  • Go基礎(chǔ)教程系列之WaitGroup用法實例詳解

    Go基礎(chǔ)教程系列之WaitGroup用法實例詳解

    這篇文章主要介紹了Go基礎(chǔ)教程系列之WaitGroup用法實例詳解,需要的朋友可以參考下
    2022-04-04
  • golang1.21泛型函數(shù)全面講解

    golang1.21泛型函數(shù)全面講解

    在Go編程語言中,泛型一直是一個備受期待的特性,隨著Go?1.21的發(fā)布,本文旨在提供Go?1.21中泛型的詳細探索,闡明它們的優(yōu)點、語法、實現(xiàn)和最佳實踐,希望對大家有所幫助
    2023-09-09
  • go mod tidy拉取依賴包bug問題及解決

    go mod tidy拉取依賴包bug問題及解決

    這篇文章主要介紹了go mod tidy拉取依賴包bug問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Golang通脈之數(shù)據(jù)類型詳情

    Golang通脈之數(shù)據(jù)類型詳情

    這篇文章主要介紹了Golang通脈之數(shù)據(jù)類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數(shù)名等等,Go語言中標識符允許由字母數(shù)字和_(下劃線)組成,并且只能以字母和_開頭,更詳細內(nèi)容請看下面文章吧
    2021-10-10
  • Go語言中實現(xiàn)完美錯誤處理實踐分享

    Go語言中實現(xiàn)完美錯誤處理實踐分享

    Go?語言是一門非常流行的編程語言,由于其高效的并發(fā)編程和出色的網(wǎng)絡(luò)編程能力,越來越受到廣大開發(fā)者的青睞。本文我們就來深入探討一下Go?語言中的錯誤處理機制吧
    2023-04-04
  • 詳解golang中模板的常用語法

    詳解golang中模板的常用語法

    這篇文章主要介紹了golang模板中的常用語法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2023-08-08
  • GO語言臨界資源安全問題的深入理解

    GO語言臨界資源安全問題的深入理解

    臨界資源安全問題也就是以往我們常聽到的線程安全問題,本文詳細的介紹了GO語言臨界資源安全問題的深入理解,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • 一文詳解Go語言中的有限狀態(tài)機FSM

    一文詳解Go語言中的有限狀態(tài)機FSM

    有限狀態(tài)機(Finite?State?Machine,F(xiàn)SM)是一種數(shù)學(xué)模型,用于描述系統(tǒng)在不同狀態(tài)下的行為和轉(zhuǎn)移條件。本文主要來和大家簡單講講Go語言中的有限狀態(tài)機FSM的使用,需要的可以參考一下
    2023-04-04

最新評論