第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

如何動(dòng)態(tài)決定處理任務(wù)的 goroutines 數(shù)量

如何動(dòng)態(tài)決定處理任務(wù)的 goroutines 數(shù)量

Go
萬(wàn)千封印 2023-06-05 18:23:24
我寫了一個(gè)虛擬代碼來(lái)演示目的。代碼中有 2 個(gè)通道和 3 個(gè)協(xié)程。1 goroutine 正在根據(jù)它們是否可以被 100 整除而沒(méi)有余數(shù)來(lái)生成數(shù)字:如果數(shù)字可以被 100 整除,則將其推送到第一個(gè)通道。否則它會(huì)將它推到第二個(gè)通道。2 個(gè) goroutines 是這些通道的消費(fèi)者:1 個(gè) goroutine 負(fù)責(zé)處理數(shù)字 1...99 - 101...199 等。其他 goroutine 負(fù)責(zé) 100、200、300 等?,F(xiàn)在很明顯,一個(gè)協(xié)程比另一個(gè)協(xié)程多 99 倍的工作要做。這在 Go 中是如何處理的?如果一個(gè) goroutine 比其他 goroutine 工作得更多,這個(gè) goroutine 是否有更多的 CPU 時(shí)間?還是我應(yīng)該處理這種情況,例如為資源消耗量更大的頻道創(chuàng)建 99 個(gè) goroutine?(為了爭(zhēng)論,這些工作被認(rèn)為是相同的)func main() {    ch1 := make(chan int)    ch2 := make(chan int)    go generator(ch1, ch2)    go handler(ch1)    go handler2(ch2)    time.Sleep(1*time.Second)}func generator(chan1, chan2 chan int){    for i:=0 ; ; i++{        if i%100 == 0{            chan1 <- i        }else{            chan2 <- i        }    }}func handler(number chan int){    for _ = range number{        num := <- number        fmt.Println("Number divided by 100 is 0. ", num)    }}func handler2(number chan int){    for _ = range number{        num := <- number        fmt.Println("Number divided by 100 is not 0. ", num)    }}
查看完整描述

2 回答

?
largeQ

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊

goroutine 獲得多少 CPU 資源取決于很多因素。

我們一般可以說(shuō)的是,僅處理可被 100 整除的數(shù)字的 goroutine 很可能比另一個(gè) goroutine 等待更多。你不應(yīng)該擔(dān)心這一點(diǎn),等待通道上的元素不需要 CPU 資源,所以如果你有“足夠”的其他 goroutines 有工作要做,他們可以利用你的 CPU。

由于顯而易見的原因,您的示例很簡(jiǎn)單,但在現(xiàn)實(shí)生活中,將您的任務(wù)抽象為一般任務(wù)(例如,處理任何數(shù)字都可能是一項(xiàng)任務(wù))、創(chuàng)建和使用一般工作池并發(fā)送所有任務(wù)會(huì)更有利可圖執(zhí)行到池中。這樣,無(wú)論池中有多少 goroutine,如果有工作要做并且有空閑(等待)goroutine,它將承擔(dān)任務(wù),盡可能利用您的 CPU 資源。作業(yè)處理器(執(zhí)行者)應(yīng)該知道如何處理數(shù)字是100101

查看完整回答
反對(duì) 回復(fù) 2023-06-05
?
冉冉說(shuō)

TA貢獻(xiàn)1877條經(jīng)驗(yàn) 獲得超1個(gè)贊

如果沒(méi)有任何內(nèi)容可供ch2閱讀,handler2則什么也不做。同時(shí),handler1忙于處理它從中讀取的內(nèi)容 ch1。這會(huì)消耗更多的 CPU 時(shí)間。

從啟動(dòng)三個(gè) Goroutine 到數(shù)據(jù)在通道上可用需要多長(zhǎng)時(shí)間會(huì)很有趣。有可能generator之前已經(jīng)完成了所有工作handler1handler2準(zhǔn)備好從通道中讀取。在這種情況下,handler2將很快完成其工作,同時(shí)handler1還有工作要做。

您當(dāng)然可以創(chuàng)建更多 Goroutines,它們handler1將以一種循環(huán)方式處理數(shù)據(jù)。根據(jù)工作的性質(zhì),這可能會(huì)提高或降低整體性能。

順便說(shuō)一句,generator應(yīng)該在一切都寫完的時(shí)候。closech1ch2


查看完整回答
反對(duì) 回復(fù) 2023-06-05
  • 2 回答
  • 0 關(guān)注
  • 164 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)