问题描述:
Golang 实现:
使用两个 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 的大小还是先判断管道是否有值。
稍有不慎就会发生死锁哦。
使用两个 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()
}
|
到此这篇关于golang 两个go程轮流打印一个切片的实现的文章就介绍到这了,更多相关golang go程轮流打印一个切片内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://www.cnblogs.com/lpgit/p/13539657.html