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