首页 > 请教一个golang的并发下,chan通道关闭

请教一个golang的并发下,chan通道关闭

我的问题是这样的, 我用了一个函数并发递归扫描一个目录(里面有几十万个甚至百万个文件),然后获取每个文件的信息(文件名,创建日期,大小等).发送到一个chan. 然后有另一个等待的goruntine从chan里面读数据,把读取的数据跟服务器的数据进行对比...... 请问我如何确定所有的文件读完了,然后关闭这个chan.(如果不用超时的话)


用select,实现代码如下:
先创建一个channel c 用于发送和接收整数

var c chan int

每一个文件处理完后,就发送整数1到c

func DoSomething(o interface{}){
    o.dosomething()
    c <- 1
}

然后在主函数中加下面代码:

L: for { 
           select { 
               case <−c:
                   i++ 17 
                   if i > 1 {
                         break L
                            }
                   }
            }

现在将会一直等待下去。只有当从 channel c 上收到多个响应时才会退出循环 L。
使其并行运行
注意这里如果有1000000万个文件,就修改为i >1000000 就可以了

【热门文章】
【热门文章】