diff options
| author | Martin Möhrmann <moehrmann@google.com> | 2016-11-14 08:05:45 +0100 |
|---|---|---|
| committer | Martin Möhrmann <moehrmann@google.com> | 2017-02-24 22:53:05 +0000 |
| commit | 4b3e6fe123d95f461d8f9febfe782a138ba2387c (patch) | |
| tree | 18a993776f31a77e2e7e019c7fbc08c99ad86090 /src/strings/replace_test.go | |
| parent | 221bc23af6feeab821c49ad11f4661270d310ecd (diff) | |
| download | go-4b3e6fe123d95f461d8f9febfe782a138ba2387c.tar.xz | |
strings: speed up Map
name old time/op new time/op delta
ByteByteMap-4 2.03µs ± 2% 1.03µs ± 2% -49.24% (p=0.000 n=10+10)
Map/identity/ASCII-4 246ns ± 0% 158ns ± 0% -35.90% (p=0.000 n=9+9)
Map/identity/Greek-4 367ns ± 1% 273ns ± 1% -25.63% (p=0.000 n=10+10)
Map/change/ASCII-4 582ns ± 1% 324ns ± 1% -44.34% (p=0.000 n=10+10)
Map/change/Greek-4 709ns ± 2% 623ns ± 2% -12.16% (p=0.000 n=10+10)
MapNoChanges-4 171ns ± 1% 111ns ± 1% -35.36% (p=0.000 n=8+10)
Updates #17859
Change-Id: I55d7d261fdc1ce2dcd0ebe23b0fa20b9889bf54c
Reviewed-on: https://go-review.googlesource.com/33201
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Diffstat (limited to 'src/strings/replace_test.go')
| -rw-r--r-- | src/strings/replace_test.go | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/strings/replace_test.go b/src/strings/replace_test.go index 77e48b988b..34b5badfad 100644 --- a/src/strings/replace_test.go +++ b/src/strings/replace_test.go @@ -540,3 +540,44 @@ func BenchmarkByteByteMap(b *testing.B) { Map(fn, str) } } + +var mapdata = []struct{ name, data string }{ + {"ASCII", "a b c d e f g h i j k l m n o p q r s t u v w x y z"}, + {"Greek", "α β γ δ ε ζ η θ ι κ λ μ ν ξ ο π ρ ς σ τ υ φ χ ψ ω"}, +} + +func BenchmarkMap(b *testing.B) { + mapidentity := func(r rune) rune { + return r + } + + b.Run("identity", func(b *testing.B) { + for _, md := range mapdata { + b.Run(md.name, func(b *testing.B) { + for i := 0; i < b.N; i++ { + Map(mapidentity, md.data) + } + }) + } + }) + + mapchange := func(r rune) rune { + if 'a' <= r && r <= 'z' { + return r + 'A' - 'a' + } + if 'α' <= r && r <= 'ω' { + return r + 'Α' - 'α' + } + return r + } + + b.Run("change", func(b *testing.B) { + for _, md := range mapdata { + b.Run(md.name, func(b *testing.B) { + for i := 0; i < b.N; i++ { + Map(mapchange, md.data) + } + }) + } + }) +} |
