本篇文章为大家展示了golang 使用两个go程轮流打印一个切片,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
Golang 实现:
使用两个 channel,只用来判断
package main
import (
"fmt"
"sync"
)
// 两个 go 程轮流打印一个切片
func main() {
ch2 := make(chan bool, 1)
ch3 := make(chan bool, 1)
ch2 <- 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) && <-ch2; i++ {
fmt.Println(nums[i])
ch3 <- true
}
wg.Done()
}()
go func() {
for ; <-ch3 && i < len(nums); i++ {
fmt.Println(nums[i])
ch2 <- true
}
wg.Done()
}()
wg.Wait()
}
注意
要理清两个子 go 程的判断条件,要注意是先判断 i 的大小还是先判断管道是否有值。
稍有不慎就会发生死锁哦。
使用两个 channel,用来传值
package main
import (
"fmt"
"sync"
)
// 两个 go 程轮流打印一个切片
func main() {
ch2 := make(chan int, 1)
ch3 := make(chan int, 1)
nums := []int{1, 2, 3, 4, 5, 6, 7, 8, 9}
ch2 <- nums[0]
i := 1
numsLen := len(nums)
var wg sync.WaitGroup
wg.Add(2)
go func() {
for ; i < numsLen; i++ {
val := <-ch2
fmt.Println(val)
ch3 <- i+1
}
wg.Done()
}()
go func() {
for ; i < numsLen; i++ {
val := <- ch3
fmt.Println(val)
ch2 <- i+1
}
wg.Done()
}()
wg.Wait()
}
上述内容就是golang 使用两个go程轮流打印一个切片,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。