如何理解Go并發(fā)中的

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)如何理解Go并發(fā)中的,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

成都創(chuàng)新互聯(lián)于2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元江城做網(wǎng)站,已為上家服務(wù),為江城各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:13518219792

Go并發(fā)中WaitGroup的使用介紹。

對(duì)于Go的并發(fā)編程來(lái)說(shuō),主協(xié)程需要知道其他的協(xié)程何時(shí)結(jié)束。通常我們的做法是采用channel的方式來(lái)控制,這種做法很好,可以參見(jiàn)我的另外一個(gè)帖子(Go并發(fā)之channel篇:https://mp.weixin.qq.com/s/PIb-gGBootc6581pHhi5ew)。但是對(duì)于一些簡(jiǎn)單的協(xié)程控制來(lái)說(shuō),channel顯得有些大材小用,而WaitGroup就可以派上用場(chǎng)了。

一、WaitGroup定義

WaitGroup是Go pkg中sync 包里的內(nèi)容:https://golang.org/pkg/sync/,一個(gè) WaitGroup 會(huì)等待一系列 goroutine 直到它們?nèi)窟\(yùn)行完畢為止。主 goroutine 通過(guò)調(diào)用 Add 方法來(lái)設(shè)置需要等待的 goroutine 數(shù)量, 而每個(gè)運(yùn)行的 goroutine 則在它們運(yùn)行完畢時(shí)調(diào)用 Done 方法。與此同時(shí), 調(diào)用 Wait 方法可以阻塞直到所有 goroutine 都運(yùn)行完畢為止。

1.主協(xié)程對(duì)其他協(xié)程什么都不處理的例子:

如何理解Go并發(fā)中的

通過(guò)上面的輸出可以看出,主協(xié)程并沒(méi)有等待其他協(xié)程的結(jié)束,就自己退出了,所以看不到關(guān)于其他協(xié)程的任何打印。

2.主協(xié)程通過(guò)超時(shí)機(jī)制來(lái)等待其他協(xié)程結(jié)束的例子:

如何理解Go并發(fā)中的

在主協(xié)程中新加了超時(shí)1s來(lái)等待其他協(xié)程的結(jié)束,通過(guò)打印可以看出來(lái),其他協(xié)程已經(jīng)運(yùn)行并結(jié)束。

3.使用wg的例子:

如何理解Go并發(fā)中的

通過(guò)打印信息可以看到,主協(xié)程通過(guò)wg.Wait()來(lái)判斷計(jì)數(shù)器有沒(méi)有變?yōu)?,來(lái)判斷其他的協(xié)程有沒(méi)有結(jié)束,在主協(xié)程檢測(cè)到wg的計(jì)數(shù)器變?yōu)?之后,便知道其他協(xié)程都已經(jīng)結(jié)束了。

二、WaitGroup中的API介紹

1. (*WaitGroup) Add 方法

func(wg*WaitGroup)Add(delta int) 

delta可以為正數(shù),也可以為負(fù)數(shù),在wg對(duì)應(yīng)的計(jì)數(shù)器沒(méi)有變?yōu)?之前delta可以為負(fù)數(shù),但是切記不要讓wg計(jì)數(shù)器變?yōu)樨?fù)數(shù),因?yàn)橐坏┳優(yōu)樨?fù)數(shù),便會(huì)panic。

通常Add在協(xié)程啟動(dòng)之前使用。

2. (*WaitGroup) Done 方法

func(wg*WaitGroup)Done() 

對(duì)wg計(jì)數(shù)器進(jìn)行減1操作。

通常Done在協(xié)程執(zhí)行結(jié)束的時(shí)候使用。

3.(*WaitGroup) Wait 方法

func(wg*WaitGroup)Wait()

阻塞直至 WaitGroup 計(jì)數(shù)器的值為 0 。

通常在主協(xié)程中使用,用來(lái)等待其他的協(xié)程結(jié)束。

上述就是小編為大家分享的如何理解Go并發(fā)中的了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站題目:如何理解Go并發(fā)中的
轉(zhuǎn)載來(lái)源:http://bm7419.com/article2/pcdcoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、面包屑導(dǎo)航、軟件開(kāi)發(fā)、外貿(mào)建站、品牌網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化