問題描述:

兩個 go 程輪流打印一個切片。git

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 的大小仍是先判斷管道是否有值。golang

稍有不慎就會發生死鎖哦。網站

使用兩個 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()
}

李培冠博客

歡迎訪問個人我的網站:code

李培冠博客:lpgit.comget