Gogoroutine的使用——“使用两个goroutine,一个打印数字,一个打印字母实现‘12AB34CD56EF78GH910IJ’”

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

你可能感兴趣的:(go相关)