我的问题是这样的, 我用了一个函数并发递归扫描一个目录(里面有几十万个甚至百万个文件),然后获取每个文件的信息(文件名,创建日期,大小等).发送到一个chan. 然后有另一个等待的goruntine从chan里面读数据,把读取的数据跟服务器的数据进行对比...... 请问我如何确定所有的文件读完了,然后关闭这个chan.(如果不用超时的话)
我的问题是这样的, 我用了一个函数并发递归扫描一个目录(里面有几十万个甚至百万个文件),然后获取每个文件的信息(文件名,创建日期,大小等).发送到一个chan. 然后有另一个等待的goruntine从chan里面读数据,把读取的数据跟服务器的数据进行对比...... 请问我如何确定所有的文件读完了,然后关闭这个chan.(如果不用超时的话)
7 回答5.4k 阅读
6 回答7k 阅读✓ 已解决
4 回答2.4k 阅读
1 回答3.4k 阅读
2 回答966 阅读✓ 已解决
2 回答2.3k 阅读
1 回答2.2k 阅读
用select,实现代码如下:
先创建一个channel c 用于发送和接收整数
每一个文件处理完后,就发送整数1到c
然后在主函数中加下面代码:
现在将会一直等待下去。只有当从 channel c 上收到多个响应时才会退出循环 L。
使其并行运行
注意这里如果有1000000万个文件,就修改为i >1000000 就可以了