好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 解決Golang 中使用WaitGroup的那點坑

解決Golang 中使用WaitGroup的那點坑

熱門標簽:涿州代理外呼系統(tǒng) 電話機器人軟件免費 百度地圖標注后傳給手機 評價高的400電話辦理 壽光微信地圖標注 外呼系統(tǒng)顯本地手機號 阿克蘇地圖標注 excel地圖標注分布數(shù)據(jù) 外呼系統(tǒng)用什么卡

sync.WaitGroup對于Golang開發(fā)者來說并不陌生,其經(jīng)常作為多協(xié)程之間同步的一種機制。用好它勢必會讓你事半功倍,但是一旦錯用將引發(fā)問題。

關(guān)于WaitGroup的使用網(wǎng)上有很多例子,在此就不做介紹了,我想說的是我在項目中使用WaitGroup遇到的坑。

在項目中,因為服務(wù)器有同步需求, 所以直接使用了WaitGroup,但是未考慮使用場景,結(jié)果在項目上線之后,高峰期的時候客戶端經(jīng)常出現(xiàn)卡頓,經(jīng)過多方查找,才發(fā)現(xiàn)如果使用WaitGroup的時候,未啟動單獨的goroutine,那么極有可能造成主線程的阻塞

所以我做了下面的測試(測試中,我把WaitGroup置于協(xié)程內(nèi)):

import (
 "fmt"
 "sync"
 "time"
)
 
func main() {
    fmt.Println("main-1")
 testW()
 fmt.Println("main-2")
 time.Sleep(time.Duration(15) * time.Second) 
}
 
func testW() {
 fmt.Println("testW-1")
 go func() {
  var wg sync.WaitGroup
  fmt.Println("testW-2")
  testW1(wg)
  fmt.Println("testW-5")
  wg.Wait()
  fmt.Println("testW-6")
 }()
}
 
func testW1(wg *sync.WaitGroup) {
 wg.Add(1)
 fmt.Println("testW-3")
 time.AfterFunc(time.Second*5, func() {
  wg.Done()
 })
 fmt.Println("testW-4")
 
}

輸出為:

main-1

testchan-1

main-2

testchan-2

testchan-3

testchan-4

testchan-5

// 過5秒

testchan-6

總結(jié):

將WaitGroup用于goroutine內(nèi),不會導致主線程的阻塞,同樣可以實現(xiàn)同步的效果。

補充:WaitGroup的簡單用法(等待組)

你品一下人家這名字,等待組。等待什么,等待goroutine完成啊。有些時候,我們啟動多個goroutine去執(zhí)行任務(wù),我舉個例子

listip := []string{"10.0.9.11","10.0.9.22","10.0.9.33"}
for _, ip := range(listip) {
    //假設(shè)我們執(zhí)行一個ping ip 的邏輯
    go PingIPWork(ip)
}

我這里執(zhí)行了一個多ip去ping的邏輯,一般這種時候,你要是執(zhí)行一波,人家肯定毛都不會返回給你,為什么?因為人家主線程直接就退出了,還是那句話,你又沒告訴人家主線程要等這ip全部都ping 完,所以你必須要加個等待,等著Goroutine完成,這里我再舉一個網(wǎng)上的例子

package main
import (
    "fmt"
)
func main() {
    go func() {
        fmt.Println("Goroutine 1")
    }()
    go func() {
        fmt.Println("Goroutine 2")
    }()
    //來個睡眠,等Goroutine結(jié)束
    time.Sleep(time.Second * 1)
}

看到了么,加了一個sleep,用sleep去等著Goroutine跑完,上面我舉的那個例子也可以這么來

listip := []string{"10.0.9.11","10.0.9.22","10.0.9.33"}
for _, ip := range(listip) {
    //假設(shè)我們執(zhí)行一個ping ip 的邏輯
    go PingIPWork(ip)
}
time.Sleep(time.Second * 1)

加個sleep可以等待完成,但是萬一啊,Goroutine有的跑的快,有的慢,你那sleep就一秒,要是有的Goroutine沒跑完不就白瞎了嗎,所以咱們需要一個機制,這個機制可以幫助咱們?nèi)ス芾鞧oroutine,讓我們知道Goroutine這東西什么時候停,什么時候完成。

所以,WaitGroup這個東西,就可以幫助我們解決這個問題,還是老樣子,我舉一個簡單的例子來說明我的想法。

package main
import (
    "fmt"
 "sync"
)
func PingIPWork(ip string) {
 fmt.Println(ip)
}
func main() {
    //定義一個等待阿祖
 var wg sync.WaitGroup
 wg.Add(3) // 因為有3個Ip,咱們定義三個動作,所以來三個計數(shù)
 listip := []string{"10.0.9.11","10.0.9.22","10.0.9.33"}
 for _, ip := range(listip) {
  //假設(shè)我們執(zhí)行一個ping ip 的邏輯
  go func(ip string) {
            //執(zhí)行一個work
            PingIPWork(ip)
            //操作完成之后,done一個計數(shù),也就是3-1
   wg.Done()
  }(ip)
 }
    //等待
 wg.Wait() // 等待,直到計數(shù)為0
}

這里我舉了一個簡單的例子,其實wg的用法較為簡單,在這個例子里面我們用到了

wg.wait
等待Goroutine結(jié)束之后退出主進程
wg.Add
添加Goroutine,其實你可以把它想成,可添加的最大Goroutine數(shù)
wg.Done
想象成銷毀參數(shù),當Goroutine結(jié)束之后調(diào)用,意思就是,你沒了,我減1

WaitGroup的其他注意事項

將Wg作為參數(shù)進行傳遞的時候,需要使用指針

有些時候,咱們不想寫的這么麻煩,就尋思怎么才能簡單一點,或者可變性稍微強一點,有些時候我們要把wg最為參數(shù),在函數(shù)內(nèi)部調(diào)用,我們該怎么寫呢?

package main
import (
 "fmt"
 "sync"
)
func PingIPWork(ip string, wg *sync.WaitGroup) {
 fmt.Println(ip)
 wg.Done()
}
func main() {
 var wg sync.WaitGroup
 wg.Add(3) // 因為有兩個動作,所以增加2個計數(shù)
 listip := []string{"10.0.9.11","10.0.9.22","10.0.9.33"}
 for _, ip := range(listip) {
  //假設(shè)我們執(zhí)行一個ping ip 的邏輯
  go PingIPWork(ip, wg)
  }
 wg.Wait() // 等待,直到計數(shù)為0
}

看到了么,如果你把Wg作為參數(shù)進行傳遞,你得要用指針的形式傳值,否則就會死鎖!!!!!!!!

Wg.Add的數(shù)值不能為負

wg.Add()的數(shù)值必須為正數(shù),如果為負數(shù),將會拋出異常。

panic: sync: negative WaitGroup counter
goroutine 1 [running]:
sync.(*WaitGroup).Add(0xc042008230, 0xffffffffffffff9c)
    D:/Go/src/sync/waitgroup.go:75 +0x1d0
main.main()
    D:/code/go/src/test-src/2-Package/sync/waitgroup/main.go:10 +0x54

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 在golang中使用Sync.WaitGroup解決等待的問題
  • Golang中的sync包的WaitGroup操作
  • Golang中的sync.WaitGroup用法實例
  • Golang標準庫syscall詳解(什么是系統(tǒng)調(diào)用)
  • Golang的os標準庫中常用函數(shù)的整理介紹
  • Golang 標準庫 tips之waitgroup詳解

標簽:雞西 欽州 汕頭 吐魯番 蘭州 重慶 銅川 梅河口

巨人網(wǎng)絡(luò)通訊聲明:本文標題《解決Golang 中使用WaitGroup的那點坑》,本文關(guān)鍵詞  解決,Golang,中,使用,WaitGroup,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解決Golang 中使用WaitGroup的那點坑》相關(guān)的同類信息!
  • 本頁收集關(guān)于解決Golang 中使用WaitGroup的那點坑的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 99久久国产精品免费制片| 韩国特级黄色片| 亚洲视频黄| 脱了美女内裤猛烈进入gif软件| 双性文高h| 户外老头玩老头j8视频| 蜜乳视频三区二区三区免费观看 | 国产精品被???熟女| 图片区 小说区 区 亚洲五月| 国产精品久久久久久久久久久久| 自拍 另类 综合 欧美小说| 51久久国产露脸精品国产| 人人人爽| 嗯嗯啊啊哦| 99e热久久免费精品18| 揉我胸?啊?嗯出水了描述| 色妞在线影院色| 毛片试看| 国模精品无码一区二区免费蜜桃| 女人自熨全过程无遮视频 | 亚洲美女性生活| 婷婷久久五月色综合小说| 机机对机机免费120分钟| 国产精品剧情| 最黄一级片| 黄鳝钻进下面好爽小说| 成人久久18秘?免费网站漫画| 巨爆乳肉感一区二区三区| 国产在线啪| 亚洲经典一曲二曲三曲第1集| 国产精品偷伦在线观看| 奴役性狂虐囚禁极端| 男男高h浪荡下拉漫画| bt天堂资源种子在线8| 日本五级A片全部免费视频| 年轻女学生HD3| 他吃我下面把舌头伸进去| 日本热妇| 女人高潮一级A片免费看下载| 欧美精品成人久久Av娜美| 肚兜情趣play|