菜鸟写了个递归复制文件夹文件的程序 到了关键一步出了点小问题 主要是 CopyFile 函数 先在全局定义了一个缓冲大小为 200 的管道 但是写在 CopyFile 函数 最后的话由于 linux 系统设置文件打开的最大句柄数为 1024 会报 open too many file 错误 但是如果写在 CopyFile 函数 开头的话 整个程序又会一下就结束 无法等待运行完毕 求各位大神搭把手 99 我 8 对了 pathSlice 的长度为 2700 多
1
sunny352787 2019-07-01 16:17:36 +08:00
你加个 channel 限制一下同时 copy 的数量啊...
|
2
Ritter OP @sunny352787 抱歉 小弟愚钝 不是很明白 是在 for 循环里面加吗
|
3
sunny352787 2019-07-01 16:25:58 +08:00 1
@Ritter 用了 go 关键字,就得知道锁和同步方式啊,去查查 channel 的具体用法
在你这个设计里面,CopyChan 的定位其实错了,不应该是用它控制程序终止,而是应该用它限制 copy 文件的数量,至于如何让程序在全 copy 完再停止,可以再想想,方法很多的 |
4
misaka19000 2019-07-01 16:26:48 +08:00 2
我还以为楼主是来求脱发防治技巧的
|
5
Ritter OP @sunny352787 好的谢谢 之前看的都是用 channel 控制程序是否终止的 是我了解的太少了
|
6
Ritter OP @misaka19000 头发滞销 救救 lz 吧
|
7
misaka19000 2019-07-01 16:45:03 +08:00 1
我觉得你可以使用两个 channel,第一个 channel 用于保证当前最多有不超过 200 个 channel 在进行读写操作,另一个 channel 保证在所有的协程执行完之前主协程不会退出
|
8
Ritter OP @misaka19000 好的谢谢 我尝试一哈
|
9
sunny352787 2019-07-01 16:51:57 +08:00
@misaka19000 这个是正解,也可以用 WaitGroup,不过更麻烦,不如加个 channel 省事
|
10
misaka19000 2019-07-01 16:52:51 +08:00 1
主协程等待所有的协程结束可以使用 sync.WaitGroup 来实现
至于多个协程之间的协作,可以使用一个容量为 200 的 channel。每个协程在进入时向 channel 写入一个值,在退出时从 channel 获取一个值,由于 channel 的容量为 200,所以最多有 200 个协程可以工作;如果容量达到上限,当前协程阻塞,等到另一个协程结束(从 channel 中取出了一个值)当前协程才可以继续执行 |
11
Ritter OP @sunny352787 之前也是试过 waitgroup 但是由于协程方面写的有问题也是不行
|
12
Ritter OP @misaka19000 跪谢大佬 我试下
|
13
Ritter OP |
14
JoJoStark 2019-07-01 18:51:04 +08:00
我是来看如何防脱发的,进来后你竟然给我看这个???🐶
|
15
txy3000 2019-07-01 18:54:04 +08:00 via Android
你秃了 也变强了吗?
|
16
sunny352787 2019-07-01 19:11:08 +08:00
|
17
Laumm 2019-07-01 19:11:40 +08:00
限制并发数量,可以用信号量,也可以使用 channel
|
18
imiao 2019-07-02 11:58:27 +08:00 via Android
只有我是进来找治秃头配方的吗
|