問題描述:
Golang 實現(xiàn):
使用兩個 channel,只用來判斷
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
package main import ( "fmt" "sync" ) // 兩個 go 程輪流打印一個切片 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() } |
注意
要理清兩個子 go 程的判斷條件,要注意是先判斷 i 的大小還是先判斷管道是否有值。
稍有不慎就會發(fā)生死鎖哦。
使用兩個 channel,用來傳值
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
package main import ( "fmt" "sync" ) // 兩個 go 程輪流打印一個切片 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 兩個go程輪流打印一個切片的實現(xiàn)的文章就介紹到這了,更多相關(guān)golang go程輪流打印一個切片內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://www.cnblogs.com/lpgit/p/13539657.html