加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

golang -- channel使用

发布时间:2020-12-16 18:57:13 所属栏目:大数据 来源:网络整理
导读:Channel 重复关闭channel ch:=make(chanbool)close(ch)close(ch)//这样会panic的,channel不能close两次 读取的时候channel提前关闭了channel close(ch)i:=-ch//不会panic,但是i读取到的是零值(""/false/nil) 向已经关闭的channel写数据 ch:=make(chanstring

Channel

重复关闭channel

ch:=make(chanbool)
close(ch)
close(ch)//这样会panic的,channel不能close两次

读取的时候channel提前关闭了channel

close(ch)
i:=<-ch//不会panic,但是i读取到的是零值(""/false/nil)

向已经关闭的channel写数据

ch:=make(chanstring)
close(ch)

ch<-"test"//会panic

判断channel是否close

i,ok:=<-ch
ifok{
println(i)
}else{
println("channelclosed")
}

for循环读取channel

fori:=rangech{//ch关闭时,for循环会自动结束
println(i)
}

防止读取超时

select{
case<-time.After(time.Second*2):
println("readchanneltimeout")
casei:=<-ch:
println(i)
}

防止写入超时

//其实和读取超时很像
select{
case<-time.After(time.Second*2):
println("writechanneltimeout")
casech<-"hello":
println("writeok")
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读