这是我遇到的一个有趣的情况。在使用 go-routines 进行一些数据操作之后,我需要从文件中读取,并根据我们发现的内容填充地图。这是简化的问题陈述和示例:
生成运行所需的数据gen_data.sh
#!/bin/bash
rm some.dat || :
for i in `seq 1 10000`; do
echo "$i `date` tx: $RANDOM rx:$RANDOM" >> some.dat
done
如果我使用 将这些行读some.dat入map[int]string没有 go-routines 中loadtoDict.go,它会保持对齐。(因为第一个和第二个词是一样的,见下面的o/p。)
在现实生活中,我确实需要在将线条加载到地图之前对其进行处理(昂贵),使用 go-routines 加快了我的字典创建速度,这是解决实际问题的重要要求。
loadtoDict.go
package main
import (
"bufio"
"fmt"
"log"
"os"
)
var (
fileName = "some.dat"
)
func checkerr(err error) {
if err != nil {
fmt.Println(err)
log.Fatal(err)
}
}
func main() {
ourDict := make(map[int]string)
f, err := os.Open(fileName)
checkerr(err)
defer f.Close()
fscanner := bufio.NewScanner(f)
indexPos := 1
for fscanner.Scan() {
text := fscanner.Text()
//fmt.Println("text", text)
ourDict[indexPos] = text
indexPos++
}
for i, v := range ourDict {
fmt.Printf("%d: %s\n", i, v)
}
}
跑步:
$ ./loadtoDict
...
8676: 8676 Mon Dec 23 15:52:24 PST 2019 tx: 17718 rx:1133
2234: 2234 Mon Dec 23 15:52:20 PST 2019 tx: 13170 rx:15962
3436: 3436 Mon Dec 23 15:52:21 PST 2019 tx: 17519 rx:5419
6177: 6177 Mon Dec 23 15:52:23 PST 2019 tx: 5731 rx:5449
注意第一个和第二个词是如何“对齐”的。但是,如果我使用 go-routines 加载我的地图,这会出错:
async_loadtoDict.go
package main
import (
"bufio"
"fmt"
"log"
"os"
"sync"
)
var (
fileName = "some.dat"
mu = &sync.RWMutex{}
MAX = 9000
)
func checkerr(err error) {
if err != nil {
fmt.Println(err)
log.Fatal(err)
}
}
泛舟湖上清波郎朗
噜噜哒
元芳怎么了
相关分类