問題描述:
兩個(gè) go 程輪流打印一個(gè)切片。
Golang 實(shí)現(xiàn):
使用兩個(gè) channel,只用來判斷
package main import ( "fmt" "sync" ) // 兩個(gè) go 程輪流打印一個(gè)切片 func main() { ch1 := make(chan bool, 1) ch2 := make(chan bool, 1) ch1 - true nums := []int{1, 2, 3, 4, 5, 6, 7, 8, 9} var i int var wg sync.WaitGroup wg.Add(2) go func() { for ; i len(nums) -ch1; i++ { fmt.Println(nums[i]) ch2 - true } wg.Done() }() go func() { for ; -ch2 i len(nums); i++ { fmt.Println(nums[i]) ch1 - true } wg.Done() }() wg.Wait() }
注意
要理清兩個(gè)子 go 程的判斷條件,要注意是先判斷 i 的大小還是先判斷管道是否有值。
稍有不慎就會(huì)發(fā)生死鎖哦。
使用兩個(gè) channel,用來傳值
package main import ( "fmt" "sync" ) // 兩個(gè) go 程輪流打印一個(gè)切片 func main() { ch1 := make(chan int, 1) ch2 := make(chan int, 1) nums := []int{1, 2, 3, 4, 5, 6, 7, 8, 9} ch1 - nums[0] i := 1 numsLen := len(nums) var wg sync.WaitGroup wg.Add(2) go func() { for ; i numsLen; i++ { val := -ch1 fmt.Println(val) ch2 - i+1 } wg.Done() }() go func() { for ; i numsLen; i++ { val := - ch2 fmt.Println(val) ch1 - i+1 } wg.Done() }() wg.Wait() }
到此這篇關(guān)于golang 兩個(gè)go程輪流打印一個(gè)切片的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)golang go程輪流打印一個(gè)切片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:保定 泰安 黔西 松原 河池 鷹潭 宜春 武漢
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang 兩個(gè)go程輪流打印一個(gè)切片的實(shí)現(xiàn)》,本文關(guān)鍵詞 golang,兩個(gè),程輪流,程,輪流,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。