go chan 阻塞协程 close

c:控制两个子协程的执行顺序
c2:控制子协程和main的执行顺序

var c2 chan int
func main() {
	c:=make(chan int)
	c2=make(chan int)
	go p1(c,"hello worldasdasdsa12312sad",true)
	go p1(c,"阿斯顿很好奇啊实打实阿萨的",false)

	// time.Sleep(1000*time.Millisecond)
	if <-c2==0{
		fmt.Println("\nover")
	}
}

func p1(c chan int,s string,b bool){
	if b{
		//读数据,读不到就会阻塞
		<-c
	}	
	for _,v:=range s{
		fmt.Printf("%c",v)
		time.Sleep(10*time.Millisecond)
	}
	//写数据
	if !b{c<-5}
	if b{c2<-0}
}
输出:
阿斯顿很好奇啊实打实阿萨的hello worldasdasdsa12312sad
over
func main() {
	c:=make(chan int,3)
	x:=5
	go func(){
		for i:=0; i<x; i++ {
			c<-i
			time.Sleep(10*time.Millisecond)
			fmt.Println(len(c),cap(c))
		}
	}()
	time.Sleep(1000*time.Millisecond)
	for i:=0; i<x; i++ {
		fmt.Println("read <-c : ",<-c)
	}
}
输出:
1 3
2 3
3 3
read <-c :  0
read <-c :  1
read <-c :  2
read <-c :  3
0 3
read <-c :  4

分析:
容量为3,写入0/1/2后在c<-i阻塞,
<-c读取0/1/2,c<-i写入3后立刻被<-c读取,
c<-i写入4后立刻被<-c读取并结束程序
func main() {
	c := make(chan int)
	i := 1
	go func() {
		for {
			c <- i
			i++
			if i == 11 {
				close(c)
				break
			}
		}
	}()
	for {
		if j, ok := <-c; ok {
			fmt.Println("read <-c : ", j)
		}else{
			fmt.Println(ok)
			break
		}
	}
}
输出如下:
read <-c :  1
read <-c :  2
read <-c :  3
read <-c :  4
read <-c :  5
read <-c :  6
read <-c :  7
read <-c :  8
read <-c :  9
read <-c :  10
false
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值