GoLang使goroutine停止的五種方法實(shí)例
GoLang之使goroutine停止的5種方法
1.goroutine停止介紹
goroutine是Go語言實(shí)現(xiàn)并發(fā)編程的利器,簡單的一個(gè)指令go function就能啟動一個(gè)goroutine;
但是,Go語言并沒有提供終止goroutine的接口,也就是說,我們不能從外部去停止一個(gè)goroutine,只能由goroutine內(nèi)部退出(main函數(shù)終止除外);
我們有很多情況下需要主動關(guān)閉goroutine,如需要實(shí)現(xiàn)一個(gè)系統(tǒng)自動熔斷的功能就需要主動關(guān)閉goroutine
2.goroutine停止的5種方法
2.1使用for-range
for-range從channel上接收值,直到channel關(guān)閉,該結(jié)構(gòu)在Go并發(fā)編程中很常用,這對于從單一通道上獲取數(shù)據(jù)去執(zhí)行某些任務(wù)是十分方便的
2.2使用for-select(向退出通道發(fā)出退出信號)
當(dāng)channel比較多時(shí),for-range結(jié)構(gòu)借不是很方便了;
Go語言提供了另外一種和channel相關(guān)的語法: select;
select能夠讓goroutine在多個(gè)通信操作上等待(可以理解為監(jiān)聽多個(gè)channel);
由于這個(gè)特性,for-select結(jié)構(gòu)在Go并發(fā)編程中使用的頻率很高;
我在使用Go的開發(fā)中,這是我用的最多的一種組合形式:
for {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> select {<!--{C}%3C!%2D%2D%20%2D%2D%3E--> } }
對于for-select結(jié)構(gòu),一般我會定義一個(gè)特定的退出通道,用于接收退出的信號,如quit
2.3使用for-select(關(guān)閉退出通道)
當(dāng)我們就需要向quit通道中發(fā)送100次數(shù)據(jù),如果再用以上的代碼就很麻煩,有一個(gè)很簡單的方法,關(guān)閉channel,這樣所有監(jiān)聽quit channel的goroutine就都會收到關(guān)閉信號,上面的代碼只要做一個(gè)很小的替換就能工作
2.4使用for-select(關(guān)閉多個(gè)channel)
如果select上監(jiān)聽了多個(gè)通道,需要所有的通道都關(guān)閉后才能結(jié)束goroutine,這里就利用select的一個(gè)特性,select不會在nil的通道上進(jìn)行等待,因此將channel賦值為nil即可,此外,還需要利用channel的ok值
var wg sync.WaitGroup func worker(in1, in2 <-chan int) { defer wg.Done() for { select { case v, ok := <-in1: if !ok { fmt.Println("收到退出信號") in1 = nil } // do something fmt.Println(v) case v, ok := <-in2: if !ok { fmt.Println("收到退出信號") in2 = nil } // do something fmt.Println(v) } // select已經(jīng)結(jié)束,我們需要判斷兩個(gè)通道的狀態(tài) // 都為nil則結(jié)束當(dāng)前goroutine if in1 == nil && in2 == nil { return } } } func main() { in1 := make(chan int) // 退出通道,接收 in2 := make(chan int) wg.Add(2) go worker(in1, in2) go worker(in2, in2) for i := 0; i < 3; i++ { in1 <- i time.Sleep(1 * time.Second) in2 <- i } close(in1) close(in2) wg.Wait() }
2.5使用context包
context包是官方提供的一個(gè)用于控制多個(gè)goroutine寫作的包;
使用context的cancel信號,可以終止goroutine的運(yùn)行,context是可以向下傳遞的
總結(jié)
到此這篇關(guān)于GoLang使goroutine停止的五種方法的文章就介紹到這了,更多相關(guān)GoLanggoroutine停止內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。