diff options
| author | Polina Osadcha <polliosa@google.com> | 2020-06-18 16:17:13 +0300 |
|---|---|---|
| committer | Martin Möhrmann <moehrmann@google.com> | 2020-08-17 04:08:35 +0000 |
| commit | 51ac0f0f4cb432204dee3d434335fd1e61ca8446 (patch) | |
| tree | 25ccafb124ef4de57b46d8156c026f8b636cbb82 /src/strings/strings_test.go | |
| parent | 6f99b33c18266a8858af96163de97173bdf6f081 (diff) | |
| download | go-51ac0f0f4cb432204dee3d434335fd1e61ca8446.tar.xz | |
strings: optimize Replace by using a strings.Builder
name old time/op new time/op delta
ReplaceAll 162ns ±26% 134ns ±26% -17.44% (p=0.014 n=10+10)
name old alloc/op new alloc/op delta
ReplaceAll 32.0B ± 0% 16.0B ± 0% -50.00% (p=0.000 n=10+10)
name old allocs/op new allocs/op delta
ReplaceAll 2.00 ± 0% 1.00 ± 0% -50.00% (p=0.000 n=10+10)
Change-Id: Ia8377141d3adb84c7bd94e511ac8f739915aeb40
Reviewed-on: https://go-review.googlesource.com/c/go/+/245197
Run-TryBot: Martin Möhrmann <moehrmann@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Keith Randall <khr@golang.org>
Diffstat (limited to 'src/strings/strings_test.go')
| -rw-r--r-- | src/strings/strings_test.go | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/strings/strings_test.go b/src/strings/strings_test.go index c01c4dabc5..09e5b27cc3 100644 --- a/src/strings/strings_test.go +++ b/src/strings/strings_test.go @@ -1900,3 +1900,12 @@ func BenchmarkTrimSpace(b *testing.B) { }) } } + +var stringSink string + +func BenchmarkReplaceAll(b *testing.B) { + b.ReportAllocs() + for i := 0; i < b.N; i++ { + stringSink = ReplaceAll("banana", "a", "<>") + } +} |
