站长资源脚本专栏

golang 两个go程轮流打印一个切片的实现

整理:jimmy2024/12/29浏览2
简介问题描述:两个 go 程轮流打印一个切片。Golang 实现:使用两个 channel,只用来判断package mainimport ("fmt""sync")// 两个 go 程轮流打印一个切片func main() {ch1 := make(chan bool, 1)ch2 := mak

问题描述:

两个 go 程轮流打印一个切片。

Golang 实现:

使用两个 channel,只用来判断

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,用来传值

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程轮流打印一个切片内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!