形式 1(应用无缓冲的 channel)
package main
import (
"fmt"
"time"
)
var flagChan = make(chan int)
func wokr1() {
for i := 1; i <= 100; i++ {
flagChan <- 666 // 塞入
if i%2 == 1 {fmt.Println("协程 1 打印:", i)
}
}
}
func wokr2() {
for i := 1; i <= 100; i++ {
_ = <-flagChan // 取出
if i%2 == 0 {fmt.Println("协程 2 打印:", i)
}
}
}
func main() {go wokr1()
go wokr2()
time.Sleep(3 * time.Second) // 能够通过 sync.WaitGroup 或者另外一个 channel 来管制主协程的退出
}
两个协程,一个 channel,把这个无缓冲的 channel 当成一把锁应用(起阻塞作用)
或者应用闭包形式,如下(与下面形式一样)
package main
import (
"fmt"
"time"
)
func main() {c := make(chan int)
go func() {
for i := 1; i < 101; i++ {
c <- 666
// 奇数
if i%2 == 1 {fmt.Println("协程 1 打印:", i)
}
}
}()
go func() {
for i := 1; i < 101; i++ {
<-c
// 偶数
if i%2 == 0 {fmt.Println("协程 2 打印:", i)
}
}
}()
time.Sleep(3 * time.Second)
}
形式 2(设置 GOMAXPROCS=1)
package main
import (
"fmt"
"runtime"
"time"
)
func main() {
// 设置可同时应用的 CPU 核数为 1
runtime.GOMAXPROCS(1)
go func() {
for i := 1; i < 101; i++ {
// 奇数
if i%2 == 1 {fmt.Println("协程 1 打印:", i)
}
// 让出 cpu
runtime.Gosched()}
}()
go func() {
for i := 1; i < 101; i++ {
// 偶数
if i%2 == 0 {fmt.Println("协程 2 打印:", i)
}
// 让出 cpu
runtime.Gosched()}
}()
time.Sleep(3 * time.Second)
}
借此能够搞清楚 runtime.GOMAXPROCS(1) 和runtime.Gosched()的应用形式
交替打印切片中奇偶数位元素的值
package main
import (
"fmt"
"time"
)
func main() {sli := make([]int, 100)
for k := 0; k < 100; k++ {sli[k] = k * 10
}
// 交替打印 sli 这个切片中奇偶数位元素的值
// fmt.Println(len(sli)) //100
c := make(chan int)
go func() {for i := 0; i < len(sli); i++ {
c <- 666
// 奇数
if i%2 == 1 {fmt.Println("协程 1 打印:", sli[i])
}
}
}()
go func() {for i := 0; i < len(sli); i++ {
<-c
// 偶数
if i%2 == 0 {fmt.Println("协程 2 打印:", sli[i])
}
}
}()
time.Sleep(3 * time.Second)
}
本文由 mdnice 多平台公布