Goroutine同步

在goroutine執(zhí)行的過程中有额,需要進(jìn)行g(shù)oroutine的同步涛漂。Go語言提供了sync包和channel機(jī)制來解決goroutine的同步問題

1. sync.WaitGroup

// 代碼來自官方文檔
package main
import (
    "fmt"
    "io/ioutil"
    "sync"
    "net/http"
)

var wg sync.WaitGroup
var urls = []string{
    "http://www.golang.org/",
    "http://www.google.com/",
    "http://www.somestupidname.com/",
}
func main() {
    for _, url := range urls {
        // Increment the WaitGroup counter.
        wg.Add(1)
        // Launch a goroutine to fetch the URL.
        go func(url string) {
            // Decrement the counter when the goroutine completes.
            defer wg.Done()
            // Fetch the URL.
            resp, err := http.Get(url)
            if err != nil {
                fmt.Println("Error is: ", err)
                return
            }
            defer resp.Body.Close()
            body, err := ioutil.ReadAll(resp.Body)
            fmt.Println(string(body))
        }(url)
    }
    // Wait for all HTTP fetches to complete.
    wg.Wait()
}
<html>
<body>
Some stupid name....
Error is:  Get http://www.google.com/: dial tcp 75.126.2.43:80: getsockopt: connection refused
Error is:  Get http://www.golang.org/: dial tcp 216.239.37.1:80: getsockopt: connection refused
// 因?yàn)闆]有翻墻瑟俭。咬像。。

2. chan

package main
import (
    "fmt"
    "io/ioutil"
    "net/http"
)

var urls = []string{
    "http://www.golang.org/",
    "http://www.google.com/",
    "http://www.somestupidname.com/",
}
var ch = make(chan string, len(urls))
func main() {
    for _, url := range urls {
        go func(url string) {
            resp, err := http.Get(url)
            if err != nil {
                str := "Error is: " + err.Error() 
                ch <- str
                return
            }
            defer resp.Body.Close()
            body, err := ioutil.ReadAll(resp.Body)
            ch <- string(body)
        }(url)
    }
    for i := 0; i < len(urls); i++ {
        str := <-ch
        fmt.Println(str)
    }
}
<html>
<body>
Some stupid name....
Error is: Get http://www.google.com/: dial tcp 173.252.102.16:80: getsockopt: connection refused
Error is: Get http://www.golang.org/: dial tcp 216.239.37.1:80: getsockopt: connection refused

channel是一種 阻塞管道 , 是自動阻塞 的. 如果 channel 滿了, 對channel放入數(shù)據(jù)的操作就會阻塞, 直到有某個(gè)routine從channel中取出數(shù)據(jù), 這個(gè)放入數(shù)據(jù)的操作才會執(zhí)行. 相反同理, 如果管道是空的, 一個(gè)從channel取出數(shù)據(jù)的操作就會阻塞,直到某個(gè)routine向這個(gè)channel中放入數(shù)據(jù), 這個(gè)取出數(shù)據(jù)的操作才會執(zhí)行(原理非常類似阻塞型socket的讀寫緩沖區(qū))

如果channel已經(jīng)close了蕾域, 在進(jìn)行讀寫操作會怎么樣呢姑裂?
總結(jié):多數(shù)情況下建議使用channel。處理比較簡單的情況時(shí)黔攒,可以選擇WaitGroup趁啸,但是處理比較復(fù)雜的邏輯時(shí)强缘,應(yīng)該使用channel。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末不傅,一起剝皮案震驚了整個(gè)濱河市旅掂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌访娶,老刑警劉巖商虐,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異崖疤,居然都是意外死亡秘车,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進(jìn)店門劫哼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來叮趴,“玉大人,你說我怎么就攤上這事权烧∶幸啵” “怎么了?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵豪嚎,是天一觀的道長搔驼。 經(jīng)常有香客問我,道長侈询,這世上最難降的妖魔是什么舌涨? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮扔字,結(jié)果婚禮上囊嘉,老公的妹妹穿的比我還像新娘。我一直安慰自己革为,他們只是感情好扭粱,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著震檩,像睡著了一般琢蛤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抛虏,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天博其,我揣著相機(jī)與錄音,去河邊找鬼迂猴。 笑死慕淡,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的沸毁。 我是一名探鬼主播峰髓,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼傻寂,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了携兵?” 一聲冷哼從身側(cè)響起疾掰,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎徐紧,沒想到半個(gè)月后个绍,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡浪汪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了凛虽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片死遭。...
    茶點(diǎn)故事閱讀 40,427評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖凯旋,靈堂內(nèi)的尸體忽然破棺而出呀潭,到底是詐尸還是另有隱情,我是刑警寧澤至非,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布钠署,位于F島的核電站,受9級特大地震影響荒椭,放射性物質(zhì)發(fā)生泄漏谐鼎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一趣惠、第九天 我趴在偏房一處隱蔽的房頂上張望狸棍。 院中可真熱鬧,春花似錦味悄、人聲如沸草戈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽唐片。三九已至,卻和暖如春涨颜,著一層夾襖步出監(jiān)牢的瞬間费韭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工咐低, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留揽思,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓见擦,卻偏偏與公主長得像钉汗,于是被迫代替她去往敵國和親羹令。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 由淺入深剖析 go channel channel 是 golang 中最核心的 feature 之一损痰,因此理解 ...
    不智魚閱讀 59,751評論 4 83
  • 介紹 如何保證在一個(gè)goroutine中看到在另一個(gè)goroutine修改的變量的值福侈,這篇文章進(jìn)行了詳細(xì)說明。 建...
    51reboot閱讀 19,682評論 11 41
  • 出處---Go編程語言 歡迎來到 Go 編程語言指南卢未。本指南涵蓋了該語言的大部分重要特性 Go 語言的交互式簡介肪凛,...
    Tuberose閱讀 18,446評論 1 46
  • Go的內(nèi)存模型 看完這篇文章你會明白 一個(gè)Go程序在啟動時(shí)的執(zhí)行順序 并發(fā)的執(zhí)行順序 并發(fā)環(huán)境下如何保證數(shù)據(jù)的同步...
    初級賽亞人閱讀 2,859評論 0 2
  • 紋身 得有多喜歡,才忍著疼辽社,抱定以后的不變伟墙,把圖案寫在皮膚里邊。 欽佩紋身人的勇敢滴铅,那勇敢承擔(dān)疼痛戳葵,也承擔(dān)風(fēng)險(xiǎn)。 ...
    靈山閱讀 260評論 0 0