真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

golang中如何控制并發(fā)數(shù)量-創(chuàng)新互聯(lián)

因為go語言層面支持并發(fā),所以面試中經(jīng)常會問到并發(fā)的問題,比如說控制go并發(fā)數(shù)量的方式有哪些?下面是我個人整理的兩個例子:

在翁源等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站設計、做網(wǎng)站 網(wǎng)站設計制作按需定制開發(fā),公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站建設,營銷型網(wǎng)站建設,外貿(mào)營銷網(wǎng)站建設,翁源網(wǎng)站建設費用合理。
func waitGroup() {
    count := 10
    wg := sync.WaitGroup{}

    for i := 0; i < count; i++ {
        wg.Add(1)
        go func(j int) {
            fmt.Print(j)
            wg.Done() // 也可使用 wg.Add(-1)
        }(i)
    }

    wg.Wait()
}

上面主要用到的是go中sync包下的waitGroup,這也是在工作中比較常見的實現(xiàn)方式,關鍵點就是把握好Add方法的位置,Wait方法則是等待所有的協(xié)程執(zhí)行完畢

func channel() {
    count := 10 // 大支持并發(fā)
    sum := 100 // 任務總數(shù)

    c := make(chan struct{}, count) // 控制任務并發(fā)的chan
    sc := make(chan struct{}, sum) // 控制任務總數(shù)的chan
    defer close(c)
    defer close(sc)

    for i:=0; i0;i-- {
        <- sc
    }
}

上面的例子用到的是go中的channel,利用channel阻塞的特性和帶緩沖的channel來實現(xiàn)控制并發(fā)數(shù)量,其中sc這個channel是可以去掉的,例子里用只是為了防止主程序退出之后,沒有全部輸出,正常工作中,程序一般都是阻塞式的,所以可以去掉。

以上就是go語言中控制并發(fā)數(shù)量的方法的詳細內(nèi)容,更多請關注創(chuàng)新互聯(lián)成都網(wǎng)站設計公司其它相關文章!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


當前文章:golang中如何控制并發(fā)數(shù)量-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://weahome.cn/article/jojdi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部