内容简介:同步操作当在一个协程里面,进行通信的话,其实就是同步操作。(这里通信是指的通过channel进行读取和写入操作,前面代码写入通道,后面代码读取操作)在用for range (或者其他大于通道长度的循环次数),会出现死锁 chan receive deadlock
情况1、同一个协程中,没有关闭通道( no close(chan))
package main import "fmt" func main() { ch := make(chan int,3) for i:=1; i <= 3; i++ { ch <- i } for data := range ch { fmt.Println("echo data :",data) } }
小结
同步操作
当在一个协程里面,进行通信的话,其实就是同步操作。(这里通信是指的通过channel进行读取和写入操作,前面代码写入通道,后面代码读取操作)
在用for range (或者其他大于通道长度的循环次数),会出现死锁 chan receive deadlock
情况2、同一个协程中,关闭通道(close(chan))
package main import "fmt" func main() { ch := make(chan int, 3) for i := 1; i <= 3; i++ { ch <- i } close(ch) for data := range ch { fmt.Println("echo data :",data) } fmt.Println("不堵塞验证") }
小结
当循环读取数据时,读取遇到关闭通道,会跳出for range 循环。
情况3、协程之间(协程)通信,会出现堵塞
package main import ( "fmt" "time" ) func main() { ch := make(chan int,3) for i:=1; i <= 3; i++ { ch <- i } go func() { for data := range ch { fmt.Println("echo data :",data) } fmt.Println("堵塞在这里") //永远输出不来 }() time.Sleep(time.Second) // 用于调试,防止子协程还没有执行,就直接退出。 }
小结
会出现堵塞,子协程会一直堵塞,直到接收到关闭channel的时候。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
疯狂Java讲义(第4版)
李刚 / 电子工业出版社 / 2018-1 / 109
《疯狂Java讲义(第4版)》是《疯狂Java讲义》的第4版,第4版保持了前3版系统、全面、讲解浅显、细致的特性,全面新增介绍了Java 9的新特性。 《疯狂Java讲义(第4版)》深入介绍了Java编程的相关方面,《疯狂Java讲义(第4版)》内容覆盖了Java的基本语法结构、Java的面向对象特征、Java集合框架体系、Java泛型、异常处理、Java GUI编程、JDBC数据库编程、J......一起来看看 《疯狂Java讲义(第4版)》 这本书的介绍吧!