Skip to content

Commit 19ce254

Browse files
committed
Update benchmarks.
1 parent ada9c8b commit 19ce254

File tree

1 file changed

+22
-22
lines changed

1 file changed

+22
-22
lines changed

README.md

Lines changed: 22 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -40,43 +40,43 @@ sem.SetLimit(new_limit) // set new semaphore limit
4040

4141

4242
### Some benchmarks
43-
Run on MacBook Pro (early 2015) with 2,7GHz Core i5 cpu and 16GB DDR3 ram:
43+
Run on MacBook Pro (2017) with 3,1GHz Core i5 cpu and 8GB DDR3 ram, macOS High Sierra, go version go1.11.4 darwin/amd64:
4444
```text
4545
// this semaphore:
46-
BenchmarkSemaphore_Acquire_Release_under_limit_simple-4 50000000 31.1 ns/op 0 B/op 0 allocs/op
47-
BenchmarkSemaphore_Acquire_Release_under_limit-4 1000000 1383 ns/op 0 B/op 0 allocs/op
48-
BenchmarkSemaphore_Acquire_Release_over_limit-4 100000 13468 ns/op 24 B/op 0 allocs/op
46+
BenchmarkSemaphore_Acquire_Release_under_limit_simple-4 20000000 98.6 ns/op 96 B/op 1 allocs/op
47+
BenchmarkSemaphore_Acquire_Release_under_limit-4 1000000 1593 ns/op 960 B/op 10 allocs/op
48+
BenchmarkSemaphore_Acquire_Release_over_limit-4 100000 20760 ns/op 9600 B/op 100 allocs/op
4949
5050
5151
// some other implementations:
5252
5353
// golang.org/x/sync/semaphore:
54-
BenchmarkXSyncSemaphore_Acquire_Release_under_limit_simple-4 30000000 51.8 ns/op 0 B/op 0 allocs/op
55-
BenchmarkXSyncSemaphore_Acquire_Release_under_limit-4 500000 2655 ns/op 0 B/op 0 allocs/op
56-
BenchmarkXSyncSemaphore_Acquire_Release_over_limit-4 20000 100004 ns/op 15991 B/op 299 allocs/op
54+
BenchmarkXSyncSemaphore_Acquire_Release_under_limit_simple-4 50000000 34.9 ns/op 0 B/op 0 allocs/op
55+
BenchmarkXSyncSemaphore_Acquire_Release_under_limit-4 1000000 1103 ns/op 0 B/op 0 allocs/op
56+
BenchmarkXSyncSemaphore_Acquire_Release_over_limit-4 30000 65927 ns/op 15985 B/op 299 allocs/op
5757
5858
// github.com/abiosoft/semaphore:
59-
BenchmarkAbiosoftSemaphore_Acquire_Release_under_limit_simple-4 5000000 269 ns/op 0 B/op 0 allocs/op
60-
BenchmarkAbiosoftSemaphore_Acquire_Release_under_limit-4 300000 5602 ns/op 0 B/op 0 allocs/op
61-
BenchmarkAbiosoftSemaphore_Acquire_Release_over_limit-4 30000 54090 ns/op 0 B/op 0 allocs/op
59+
BenchmarkAbiosoftSemaphore_Acquire_Release_under_limit_simple-4 10000000 208 ns/op 0 B/op 0 allocs/op
60+
BenchmarkAbiosoftSemaphore_Acquire_Release_under_limit-4 500000 3147 ns/op 0 B/op 0 allocs/op
61+
BenchmarkAbiosoftSemaphore_Acquire_Release_over_limit-4 50000 37148 ns/op 0 B/op 0 allocs/op
6262
6363
// github.com/dropbox/godropbox
64-
BenchmarkDropboxBoundedSemaphore_Acquire_Release_under_limit_simple-4 20000000 99.6 ns/op 0 B/op 0 allocs/op
65-
BenchmarkDropboxBoundedSemaphore_Acquire_Release_under_limit-4 1000000 1343 ns/op 0 B/op 0 allocs/op
66-
BenchmarkDropboxBoundedSemaphore_Acquire_Release_over_limit-4 100000 35735 ns/op 0 B/op 0 allocs/op
67-
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_under_limit_simple-4 30000000 56.0 ns/op 0 B/op 0 allocs/op
68-
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_under_limit-4 500000 2871 ns/op 0 B/op 0 allocs/op
69-
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_over_limit-4 30000 41089 ns/op 0 B/op 0 allocs/op
64+
BenchmarkDropboxBoundedSemaphore_Acquire_Release_under_limit_simple-4 20000000 75.9 ns/op 0 B/op 0 allocs/op
65+
BenchmarkDropboxBoundedSemaphore_Acquire_Release_under_limit-4 2000000 629 ns/op 0 B/op 0 allocs/op
66+
BenchmarkDropboxBoundedSemaphore_Acquire_Release_over_limit-4 200000 27308 ns/op 0 B/op 0 allocs/op
67+
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_under_limit_simple-4 50000000 39.7 ns/op 0 B/op 0 allocs/op
68+
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_under_limit-4 1000000 1170 ns/op 0 B/op 0 allocs/op
69+
BenchmarkDropboxUnboundedSemaphore_Acquire_Release_over_limit-4 100000 21013 ns/op 0 B/op 0 allocs/op
7070
7171
// github.com/kamilsk/semaphore
72-
BenchmarkKamilskSemaphore_Acquire_Release_under_limit_simple-4 10000000 170 ns/op 16 B/op 1 allocs/op
73-
BenchmarkKamilskSemaphore_Acquire_Release_under_limit-4 500000 3023 ns/op 160 B/op 10 allocs/op
74-
BenchmarkKamilskSemaphore_Acquire_Release_over_limit-4 20000 67687 ns/op 1600 B/op 100 allocs/op
72+
BenchmarkKamilskSemaphore_Acquire_Release_under_limit_simple-4 20000000 110 ns/op 16 B/op 1 allocs/op
73+
BenchmarkKamilskSemaphore_Acquire_Release_under_limit-4 1000000 1520 ns/op 160 B/op 10 allocs/op
74+
BenchmarkKamilskSemaphore_Acquire_Release_over_limit-4 50000 42693 ns/op 1600 B/op 100 allocs/op
7575
7676
// github.com/pivotal-golang/semaphore
77-
BenchmarkPivotalGolangSemaphore_Acquire_Release_under_limit_simple-4 1000000 1006 ns/op 136 B/op 2 allocs/op
78-
BenchmarkPivotalGolangSemaphore_Acquire_Release_under_limit-4 100000 11837 ns/op 1280 B/op 20 allocs/op
79-
BenchmarkPivotalGolangSemaphore_Acquire_Release_over_limit-4 10000 128890 ns/op 12800 B/op 200 allocs/op
77+
BenchmarkPivotalGolangSemaphore_Acquire_Release_under_limit_simple-4 3000000 558 ns/op 136 B/op 2 allocs/op
78+
BenchmarkPivotalGolangSemaphore_Acquire_Release_under_limit-4 200000 9530 ns/op 1280 B/op 20 allocs/op
79+
BenchmarkPivotalGolangSemaphore_Acquire_Release_over_limit-4 10000 111264 ns/op 12801 B/op 200 allocs/op
8080
8181
```
8282
You can rerun these benchmarks, just checkout `benchmarks` branch and run `go test -bench=. -benchmem ./bench/...`

0 commit comments

Comments
 (0)