实话实说,我之前还真的没有在意过这个chan是否关闭过
只知道
如果有一个有缓冲的chan在写入数据之后,关闭了,再去读取数据是可以读取出来的
一个没有缓冲的chan写入等待数据,关闭,然后也是可以读出这个代写入的数据的,
但是回到原来的问题,这个chan如何判断关闭呢?
我也知道,如果一个chan关闭了,直接去读取数据如果有数据就是数据没有数据就是默认值,但是不能写,写入就是panic;
OK OK,我们直接来说吧,如何判断chan的关闭呢?
方法一:OK不OK
if _, ok := <-chan; ok {
fmt.Println("--", ok)
}
这是一个很简单的方法,但是我在此之前竟然忘记了,但是也确实是在我的项目经历中关于这个chan我从来也没有关闭过,我的经历是只要程序在运行,我的chan就在一直运行,没有关闭过,也就没有了解过这个小方法。与之相似的 我却经常用,就是 判断map的key是否存在,同样是看一个key是否存在,再去获取其对应的value
方法二:
这个方法是用到的 contest的衍生方法
ctx, cancel := context.WithCancel(context.Background())
close(c)
cancel()
exit:
for {
select {
case data, ok := <-c:
fmt.Println(data, ok)
case <-ctx.Done():
break exit
这个方法也不是适用所有情况,但是可以参考