Commit 30a9957a authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

bytes: minor optimization to lastIndexFunc

Before and after:
BenchmarkTrimSpace  20000000   81.3 ns/op
BenchmarkTrimSpace  50000000   58.0 ns/op

(most whitespace trimming is ASCII whitespace)

Same optimization appeared a handful of other places
in this file, but not here.

R=golang-dev, dave
CC=golang-dev
https://golang.org/cl/7305063
parent 7594440e
...@@ -571,7 +571,10 @@ func indexFunc(s []byte, f func(r rune) bool, truth bool) int { ...@@ -571,7 +571,10 @@ func indexFunc(s []byte, f func(r rune) bool, truth bool) int {
// inverted. // inverted.
func lastIndexFunc(s []byte, f func(r rune) bool, truth bool) int { func lastIndexFunc(s []byte, f func(r rune) bool, truth bool) int {
for i := len(s); i > 0; { for i := len(s); i > 0; {
r, size := utf8.DecodeLastRune(s[0:i]) r, size := rune(s[i-1]), 1
if r >= utf8.RuneSelf {
r, size = utf8.DecodeLastRune(s[0:i])
}
i -= size i -= size
if f(r) == truth { if f(r) == truth {
return i return i
......
...@@ -1073,3 +1073,10 @@ func BenchmarkFieldsFunc(b *testing.B) { ...@@ -1073,3 +1073,10 @@ func BenchmarkFieldsFunc(b *testing.B) {
FieldsFunc(fieldsInput, unicode.IsSpace) FieldsFunc(fieldsInput, unicode.IsSpace)
} }
} }
func BenchmarkTrimSpace(b *testing.B) {
s := []byte(" Some text. \n")
for i := 0; i < b.N; i++ {
TrimSpace(s)
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment