golang 兩個go程輪流打印一個切片的實現(xiàn)
問題描述:
兩個 go 程輪流打印一個切片。
Golang 實現(xiàn):
使用兩個 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 的大小還是先判斷管道是否有值。
稍有不慎就會發(fā)生死鎖哦。
使用兩個 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()
}
到此這篇關(guān)于golang 兩個go程輪流打印一個切片的實現(xiàn)的文章就介紹到這了,更多相關(guān)golang go程輪流打印一個切片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語言kube-scheduler深度剖析開發(fā)之scheduler初始化
這篇文章主要介紹了Go語言kube-scheduler深度剖析開發(fā)之scheduler初始化實現(xiàn)過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
Go?web中cookie值安全securecookie庫使用原理
這篇文章主要為大家介紹了Go?web中cookie值安全securecookie庫使用及實現(xiàn)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11
Go1.20最新資訊go?arena手動管理內(nèi)存鴿了
由于過于繁雜,Go?核心團隊成員@Ian?Lance?Taylor,也表態(tài):目前尚未做出任何決定,也不可能在短期內(nèi)做出任何決定,可以認為這個提案基本鴿了,今天這篇文章就是給大家同步目前的情況2023-11-11

