思路:交替打印勢必需要同步,就引入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
}