-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathslovar-3.go
64 lines (55 loc) · 1.23 KB
/
slovar-3.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// Varna sočasnost
// uporabimo slovar iz paketa sync, sync.Map
package main
import (
"flag"
"fmt"
"sync"
"time"
)
var wg sync.WaitGroup
func writeToMap(id int, steps int, dict *sync.Map) {
defer wg.Done()
dict.Store(id, 0)
for i := 0; i < steps; i++ {
val, _ := dict.Load(id)
dict.Store(id, val.(int)+1) // zahtevanje tipa (type assertion)
}
}
func readFromMap(id int, steps int, dict *sync.Map) {
defer wg.Done()
for i := 0; i < steps; i++ {
_, _ = dict.Load(id)
}
}
func main() {
gwPtr := flag.Int("gw", 1, "# of writing goroutines")
grPtr := flag.Int("gr", 1, "# of reading goroutines")
sPtr := flag.Int("s", 100, "# of read or write steps")
flag.Parse()
var dict sync.Map
records := *gwPtr
if *grPtr > records {
records = *grPtr
}
for i := 0; i < records; i++ {
dict.Store(i, 0)
}
timeStart := time.Now()
for i := 0; i < *gwPtr; i++ {
wg.Add(1)
go writeToMap(i, *sPtr, &dict)
}
for i := 0; i < *grPtr; i++ {
wg.Add(1)
go readFromMap(i, *sPtr, &dict)
}
wg.Wait()
fmt.Print("dict: map[")
dict.Range(
func(k, v interface{}) bool {
fmt.Print(k, ":", v, " ")
return true
})
fmt.Println("\b] time:", time.Since(timeStart))
}