求助,关于waitgroup产生死锁问题

zhuting233 · · 1574 次点击
buguang01
https://github.com/buguang01
你是不是想着,我有一个文件,想多开几个协程一起读,是不是可以更快的读入文件? 这个问题其实可以多几个方面考虑; --- 1. 同一个文件,可以使用只读的方式,打开多个句柄,然后每个句柄从不同的位置开始读; 2. 如果读出后的处理操作很费时间的话,可以同一个文件使用一个句柄,读的时候需要加上并发锁,并发处理;
#4
更多评论
这个不是waitgroup死锁的问题,是你读文件的方式有问题 感觉你的这个写法很奇怪,没看懂你的目的是什么。
#1
buguang01
https://github.com/buguang01
我理解,你是写了一个1000行的文件,然后想并发读这个文件写到ch中;但是你发现写入ch的数据长度不对,还有时候会卡在写入ch的地方,对吧? 原因是这样的,scanner这个并不是协程安全的,你想一下,三个协程同时 scanner.Scan()然后scanner.Text()的时候,他们是分别获得三行,还是获得同一行呢?因为scanner.Scan()的时候没有锁,导致scanner里面的过程变量的值变得不可预测,这会导致读出来的数据不是正确的。所以你的这个程序会出现你现在发现的问题。
#2