当前位置:网站首页>读写关闭的channel是啥后果?
读写关闭的channel是啥后果?
2022-07-04 17:32:00 【小锟哥哥】
在 go 的面试中,最常问到的知识点无疑是 channel 了。
当 channel 关闭后再去读取数据会出现啥情况,最经常被问到。
一、正常的 channel
首先我们先来一段正常操作的代码:
ch := make(chan int, 3)
ch <- 1
ch <- 2
ch <- 3
for item := range ch {
fmt.Println(item)
}
这段代码应该非常熟悉,这样写是否有问题呢?
执行后的结果:
$ go run n.go
1
2
3
fatal error: all goroutines are asleep - deadlock!
如果一个 channel 不在某个协程里面关闭的话,我们的 for range 就会报死锁的错误。
二、关闭后再读取
1、使用 for range 读取关闭后的 channel
现在我们在 for range 之前关闭下这个 channel,看会出现啥情况:
ch := make(chan int, 3)
ch <- 1
ch <- 2
ch <- 3
close(ch)
// 如果不关闭会报死锁 fatal error: all goroutines are asleep - deadlock!
for item := range ch {
fmt.Println(item)
}
这样写代码会出现啥问题呢?
$ go run n.go
1
2
3
啥错也没有,正常的读取。
2、直接独立取值
下面我们换直接独立取值的方式:
ch := make(chan int, 3)
ch <- 1
ch <- 2
ch <- 3
close(ch)
item, state := <-ch // state 为是否读到有值
fmt.Println(item, state)
state 会返回是否取到了值,这段代码的执行结果是取到第一个值:
$ go run n.go
1 true
如果我们反复读取呢?
ch := make(chan int, 3)
ch <- 1
ch <- 2
ch <- 3
close(ch)
<-ch
<-ch
<-ch
item, state := <-ch // state 为是否读到有值
fmt.Println(item, state) //全部读完值之后,再读也不会报错,只会取到零值
我前面读取 3 次,把里面的数据读取完毕后,再读取得到就是零值了。
$ go run n.go
0 false
所以结论是:如果 channel 有元素还未读,会正确读出来,哪怕他已经关闭了。
三、往里面写值呢?
最后一起来看下,当 channel 关闭后,往里面写值会怎样?
ch := make(chan int, 3)
ch <- 1
ch <- 2
ch <- 3
close(ch)
ch <- 4
这段代码执行后的结果:
$ go run n.go
panic: send on closed channel
会报 panic,具体原因我们可以看 go 的源码,路径为:src/runtime/chan.go

边栏推荐
- Machine learning concept drift detection method (Apria)
- Li Kou brush question diary /day6/6.28
- 信息学奥赛一本通 1336:【例3-1】找树根和孩子
- 技术分享 | 接口测试价值与体系
- How to modify icons in VBS or VBE
- 未来几年中,软件测试的几大趋势是什么?
- 基于lex和yacc的词法分析器+语法分析器
- Scala基础教程--19--Actor
- Nature Microbiology | 可感染阿斯加德古菌的六种深海沉积物中的病毒基因组
- Li Kou brush question diary /day5/2022.6.27
猜你喜欢
随机推荐
C language printing exercise
My colleagues quietly told me that flying Book notification can still play like this
Perfect JS event delegation
Li Kou brush question diary /day2/2022.6.24
Scala基础教程--14--隐式转换
Wireshark抓包TLS协议栏显示版本不一致问题
Grain Mall (I)
基于C语言的菜鸟驿站管理系统
【Go语言刷题篇】Go完结篇|函数、结构体、接口、错误入门学习
力扣刷题日记/day4/6.26
基于unity的愤怒的小鸟设计
Crawler (6) - Web page data parsing (2) | the use of beautifulsoup4 in Crawlers
删除字符串中出现次数最少的字符【JS,Map排序,正则】
Using SSH
Li Kou brush question diary /day6/6.28
【uniapp】uniapp开发app在线预览pdf文件
SIGMOD’22 HiEngine论文解读
6.26cf simulation match B: solution to array reduction problem
力扣刷题日记/day7/6.30
每日一题(2022-07-02)——最低加油次数









