Golang并發編程:使用Go WaitGroup實現任務調度器
- 引言
在Golang中,實現并發編程可以大大提升程序的性能和效率。而任務調度器是并發編程中非常重要的一部分,它可以用于調度并發任務的執行順序和同步任務的完成。本文將介紹如何使用Golang中的WaitGroup來實現一個簡單的任務調度器,并給出具體的代碼示例。WaitGroup簡介
WaitGroup是Golang包sync中的一個重要類型,它提供了并發任務的同步和等待功能。WaitGroup有三個主要的方法:Add、Done和Wait。
Add(n int):添加 n 個并發任務到WaitGroup中。Done():標記一個任務完成。Wait():等待所有任務完成,并阻塞當前的goroutine。
WaitGroup內部維護了一個計數器,用來記錄未完成的任務數量。當調用Add方法時,計數器加上指定的值;當調用Done方法時,計數器減1;當調用Wait方法時,如果計數器大于0,當前goroutine會被阻塞,直到計數器歸零。
- 任務調度器實現
下面是一個使用WaitGroup實現任務調度器的示例代碼:
package main import ( "fmt" "sync" "time" ) func worker(id int, wg *sync.WaitGroup) { defer wg.Done() fmt.Printf("Worker %d starting ", id) time.Sleep(time.Second) fmt.Printf("Worker %d done ", id) } func main() { var wg sync.WaitGroup for i := 1; i <= 5; i++ { wg.Add(1) go worker(i, &wg) } wg.Wait() fmt.Println("All workers done") }
登錄后復制
在這個示例中,我們使用一個for循環啟動5個worker goroutine,并通過調用wg.Add(1)來將任務數量添加到WaitGroup中。在worker函數中,使用defer關鍵字來確保在函數返回前調用wg.Done(),來減少計數器的值。最后,使用wg.Wait()來等待所有任務完成。
- 運行結果
運行這個示例代碼,你會看到如下的輸出結果:
Worker 1 starting Worker 2 starting Worker 3 starting Worker 4 starting Worker 5 starting Worker 3 done Worker 1 done Worker 2 done Worker 5 done Worker 4 done All workers done
登錄后復制
可以看到,所有的worker goroutine被并發執行,但是輸出的順序并不一定是按照啟動順序來的,這是因為goroutine的調度是由Go運行時進行的。
- 總結
使用WaitGroup可以方便地實現并發任務的調度和同步。通過調用Add方法添加任務數量、調用Done方法標記任務完成、調用Wait方法來等待任務完成,可以實現任務的同步和順序控制。在實際應用中,任務調度器可以用于處理并發任務、限制并發數量等場景,幫助我們更好地利用Golang的并發能力。
通過本文的介紹和示例代碼,相信你對如何使用Golang的WaitGroup實現任務調度器有了更深的理解。希望本文對你學習和使用Golang的并發編程有所幫助!
以上就是Golang并發編程:使用Go WaitGroup實現任務調度器的詳細內容,更多請關注www.xfxf.net其它相關文章!