关闭2次
ch := make(chan bool)
close(ch)
close(ch) // 这样会panic的,channel不能close两次
读取的时候channel提前关闭了
ch := make(chan string)
close(ch)
i := <- ch // 不会panic, i读取到的值是空 "", 如果channel是bool的,那么读取到的是false
向已经关闭的channel写数据
ch := make(chan string)
close(ch)
ch <- "good" // 会panic的
判断channel是否close
i, ok := <- ch
if ok {
println(i)
} else {
println("channel closed")
}
for循环读取channel
for i := range ch { // ch关闭时,for循环会自动结束
println(i)
}
防止读取超时
select {
case <- time.after(time.second*2):
println("read channel timeout")
case i := <- ch:
println(i)
}
防止写入超时
// 其实和读取超时很像
select {
case <- time.after(time.second *2):
println("write channel timeout")
case ch <- "hello":
println("write ok")
}
如对本文有疑问,
点击进行留言回复!!
相关文章:
-
-
-
-
Go打包二进制文件的实现
背景众所周知,go语言可打包成目标平台二进制文件是其一大优势,如此go项目在服务器不需要配置go环境和依赖就可跑起来。操作需求:打包部署到centos7笔者打包...
[阅读全文]
-
-
-
-
golang语言编码规范的实现
本规范旨在为日常go项目开发提供一个代码的规范指导,方便团队形成一个统一的代码风格,提高代码的可读性,规范性和统一性。本规范将从命名规范,注释规范,代码风格和 ...
[阅读全文]
-
-
-
网友评论