思路:交替打印势必需要同步,就引入chan 通道的想法 ,简单模拟了锁的功能,
创建两个chan ,
goroutine 1 :for循环 :打印数字前上锁(从chan1读,若chan1无数据,即阻塞),若有数据,开始打印12
打印完给给chan2写如数据,(即给通道2释放锁),此时阻塞在读chan1中
goroutine 2:for循环 :打印字母前上锁(从chan2读,若chan2无数据,即阻塞,这里就能明白为什么goroutine1结束之后再向chan2写数据了,为的就是保证goroutine2在1之后执行)打印AB,打印完成后给chan1写数据,此时,阻塞在chan2中,
最后将描述翻译成代码即可,但是还需要加一个chan写的操作在goroutine2循环之后,在主程序末尾读chan,目的是让程序等待两个goroutine结束之后再退出。
不额外加一个chan的结果就是看不到程序任何的输出,是因为主程序并不会等待其他goroutine的结束
package main
import (
"fmt"
)
var chan1 = make(chan bool, 1)
var chan2 = make(chan bool)
var index = make(chan bool, 1)
var str = "ABCDEFGHIJ"
func func1() {
for i := 1; i < 11; i += 2 {
<-chan1
fmt.Println(i)
fmt.Println(i + 1)
chan2 <- true
}
}
func func2() {
size := len(str)
for i := 0; i < size; i += 2 {
<-chan2
fmt.Println(str[i])
fmt.Println(str[i+1])
chan1 <- true
}
index <- true
}
func main() {
chan1 <- true
go func1()
go func2()
<-index
}