什么是goroutine?
Goroutine是建立在線程之上的輕量級的抽象。它允許我們以非常低的代價在同一個地址空間中并行地執(zhí)行多個函數(shù)或者方法。相比于線程,它的創(chuàng)建和銷毀的代價要小很多,并且它的調(diào)度是獨立于線程的。在golang中創(chuàng)建一個goroutine非常簡單,使用“go”關(guān)鍵字即可:
package mainimport ( "fmt" "time")func learning() { fmt.Println("My first goroutine")}func main() { go learning() /* we are using time sleep so that the main program does not terminate before the execution of goroutine.*/ time.Sleep(1 * time.Second) fmt.Println("main function")}
這段代碼的輸出是這樣的:
My first goroutinemain function
如果把Sleep去掉的話,輸出就會變成:
main function
這是因為,和線程一樣,golang的主函數(shù)(其實也跑在一個goroutine中)并不會等待其它goroutine結(jié)束。如果主goroutine結(jié)束了,所有其它goroutine都將結(jié)束。
下面看下Go語言學習之goroutine的相關(guān)內(nèi)容。
協(xié)程Coroutine
特點
- 輕量級的“線程”
- 非搶占式多任務(wù)處理,由協(xié)程主動交出控制權(quán)
- 編譯器/解釋器/虛擬機層面的多任務(wù),非操作系統(tǒng)
- 多個協(xié)程可以在一個或多個線程上執(zhí)行
go關(guān)鍵字開啟一個協(xié)程
func main() {
for i := 0; i 10; i++ {
go func(i int) {
for {
fmt.Println(i)
}
}(i)
}
time.Sleep(time.Millisecond)
}
goroutine可能的切換點(轉(zhuǎn)讓控制權(quán))
- I/O,select
- channel
- 等待鎖
- 函數(shù)調(diào)用(有時)
- routime.Goshed()
- 只是參考,不能保證切換,不能保證在其他地方不切換
總結(jié)
以上所述是小編給大家介紹的Go語言學習之goroutine詳解,希望對大家有所幫助!
您可能感興趣的文章:- golang 并發(fā)編程之生產(chǎn)者消費者詳解
- golang并發(fā)編程的實現(xiàn)
- Go并發(fā)編程實踐
- GO語言并發(fā)編程之互斥鎖、讀寫鎖詳解
- Golang Goroutine的使用
- Go并發(fā)編程之正確使用goroutine的方法