鍍金池/ 問答/GO  Linux/ 怎樣理解golang的異步?

怎樣理解golang的異步?

都說golang,可以用同步的思想寫出異步的代碼,不知道大家都是如何理解這句話的?
下面這段代碼算是這句話的一個(gè)例子嗎?


func sum(x,y int,c chan int){
    time.sleep(5*time.Second)
    c <- x + y
}

func another(c chan int){
    fmt.Println(<-c)      //管道有數(shù)據(jù)了直接繼續(xù)執(zhí)行,相當(dāng)于異步通知
    do something else...
}

func main(){
    c := make (chan int)
    go sum(24,18,c)
    go another(c)
    fmt.Println("繼續(xù)執(zhí)行")
    do something else...
    time.Sleep(60*time.Second)
}

此外,再說一下我對(duì)同步異步阻塞非阻塞的理解:

阻塞非阻塞:一般用于網(wǎng)絡(luò)io中,阻塞即需要等待,不會(huì)立即返回。非阻塞則會(huì)立刻返回。

同步異步:當(dāng)一個(gè)同步調(diào)用發(fā)出后,調(diào)用者要主動(dòng)去獲取調(diào)用結(jié)果。當(dāng)一個(gè)異步過程調(diào)用發(fā)出后,實(shí)際處理這個(gè)調(diào)用的部件在完成后,通過消息回調(diào)來通知調(diào)用者調(diào)用的結(jié)果。

可以明確的是,阻塞與非阻塞與是否同步異步無關(guān)

附贈(zèng)一個(gè)講解阻塞非阻塞和同步異步挺清楚的一篇文章,傳送門:https://www.cnblogs.com/wxl-d...

回答
編輯回答
玄鳥

用同步的思想寫出異步的代碼這句話我在golang沒有聽過。如果非要說這個(gè)事的話,目前我只知道javascript的async/await是可以理解為用同步的思想寫出異步的代碼。

好了,回到問題上來,你的問題這里用同步的思想寫出異步的代碼,golang有是有這個(gè),那就是go關(guān)鍵字。
不管什么操作,都可以加上go關(guān)鍵詞來實(shí)現(xiàn)異步前提是go調(diào)度器會(huì)把執(zhí)行權(quán)給到你這個(gè)協(xié)程,一般發(fā)生阻塞go調(diào)度器就會(huì)切換協(xié)程

2018年7月11日 04:21
編輯回答
孤客

emmm……糾正一個(gè),阻塞和非阻塞不是用來描述 IO 的,IO 一定是阻塞的……

2017年12月25日 16:59
編輯回答
放開她

其實(shí)你這個(gè)例子就很好的說明了這一點(diǎn)啊,用同步的思想寫異步的代碼。

也正是因?yàn)橛凶枞拇嬖?,你這段代碼才能夠 “同步”地執(zhí)行

然后你說,同步和阻塞之間在概念上沒有必然的聯(lián)系,這個(gè)話本質(zhì)上是對(duì)的,但是矛盾的雙方在一定條件下是能相互轉(zhuǎn)換的:

同步的意思是,后一條指令必須要等待上一條指令執(zhí)行完成后,才開始運(yùn)行;異步呢就是,上一條指令啟動(dòng)后,就在“另一個(gè)維度”運(yùn)行了,和下一條指令好像是同時(shí)運(yùn)行的,更為生動(dòng)的說法,我照搬一下一個(gè)百度知道的神比喻

你給了狗一個(gè)包子,然后就走開做別的事去了,過后狗追過來對(duì)你說了聲謝謝,
或者咬了你一口說,包子有毒。這是異步。

同樣你給了狗一個(gè)包子后,看著狗把包子吃完,并對(duì)你搖尾巴,這個(gè)期間你一點(diǎn)別的
事都不做,就等著狗吃完包子。 這是同步。

用你問題中的代碼,可以理解為:

你再給了狗一個(gè)包子,然后就呆在原地除了等狗啥都不做,過會(huì)兒狗追過來對(duì)你說了聲謝謝,你再心滿意足地繼續(xù)做自己的事情,這就是將異步阻塞后變成的同步。

所以呢,同步和阻塞還是有那么些聯(lián)系的(如果你把它們?nèi)嘣谝黄鸬脑挘?/p>

再說回 golang,其實(shí)你代碼中,也就兩個(gè) go 語句是達(dá)到這個(gè)效果了的,但相對(duì)于 fmt.Println("繼續(xù)執(zhí)行") 以及后面的代碼來說,前兩條語句還是異步執(zhí)行的,并且它不像 javascript 那樣只是單線程工作(并發(fā)),golang 協(xié)程是可以多個(gè)同時(shí)工作的(并行)

2017年3月17日 03:15