aboutsummaryrefslogtreecommitdiff
path: root/src/encoding/base64
diff options
context:
space:
mode:
authorKirill Korotaev <kirillx@gmail.com>2020-04-22 20:19:21 +0000
committerIan Lance Taylor <iant@golang.org>2020-04-22 21:36:41 +0000
commit9a93baf4d7d13d7d5c67388c93960d78abc8e11e (patch)
tree3370dbb5bcae2c048e4e78aee5db6e295ea86c08 /src/encoding/base64
parent0ee4b13830572ad66cdcc045d1e4ae1e15a87ebb (diff)
downloadgo-9a93baf4d7d13d7d5c67388c93960d78abc8e11e.tar.gz
go-9a93baf4d7d13d7d5c67388c93960d78abc8e11e.zip
encoding/base64: improve performance up to 20% total
Improve base64 encoding/decoding performance by suppressing compiler boundary checks on decode. name old speed new speed delta EncodeToString-8 570MB/s ± 1% 573MB/s ± 1% ~ (p=0.421 n=5+5) DecodeString/2-8 88.6MB/s ± 3% 91.6MB/s ± 2% +3.37% (p=0.016 n=5+5) DecodeString/4-8 162MB/s ± 1% 168MB/s ± 0% +4.12% (p=0.008 n=5+5) DecodeString/8-8 203MB/s ± 0% 214MB/s ± 0% +5.18% (p=0.008 n=5+5) DecodeString/64-8 471MB/s ± 1% 520MB/s ± 1% +10.50% (p=0.008 n=5+5) DecodeString/8192-8 757MB/s ± 0% 895MB/s ± 1% +18.29% (p=0.008 n=5+5) Change-Id: I135243c11aa4c974a4a4e95c5c2abb0635d52c8c GitHub-Last-Rev: 2c87abcb287f4459888941ae2633edcd8eb5b79d GitHub-Pull-Request: golang/go#36910 Reviewed-on: https://go-review.googlesource.com/c/go/+/217117 Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
Diffstat (limited to 'src/encoding/base64')
-rw-r--r--src/encoding/base64/base64.go26
1 files changed, 14 insertions, 12 deletions
diff --git a/src/encoding/base64/base64.go b/src/encoding/base64/base64.go
index 690d3ce042..0c33f8e5f8 100644
--- a/src/encoding/base64/base64.go
+++ b/src/encoding/base64/base64.go
@@ -480,15 +480,16 @@ func (enc *Encoding) Decode(dst, src []byte) (n int, err error) {
si := 0
for strconv.IntSize >= 64 && len(src)-si >= 8 && len(dst)-n >= 8 {
+ src2 := src[si : si+8]
if dn, ok := assemble64(
- enc.decodeMap[src[si+0]],
- enc.decodeMap[src[si+1]],
- enc.decodeMap[src[si+2]],
- enc.decodeMap[src[si+3]],
- enc.decodeMap[src[si+4]],
- enc.decodeMap[src[si+5]],
- enc.decodeMap[src[si+6]],
- enc.decodeMap[src[si+7]],
+ enc.decodeMap[src2[0]],
+ enc.decodeMap[src2[1]],
+ enc.decodeMap[src2[2]],
+ enc.decodeMap[src2[3]],
+ enc.decodeMap[src2[4]],
+ enc.decodeMap[src2[5]],
+ enc.decodeMap[src2[6]],
+ enc.decodeMap[src2[7]],
); ok {
binary.BigEndian.PutUint64(dst[n:], dn)
n += 6
@@ -504,11 +505,12 @@ func (enc *Encoding) Decode(dst, src []byte) (n int, err error) {
}
for len(src)-si >= 4 && len(dst)-n >= 4 {
+ src2 := src[si : si+4]
if dn, ok := assemble32(
- enc.decodeMap[src[si+0]],
- enc.decodeMap[src[si+1]],
- enc.decodeMap[src[si+2]],
- enc.decodeMap[src[si+3]],
+ enc.decodeMap[src2[0]],
+ enc.decodeMap[src2[1]],
+ enc.decodeMap[src2[2]],
+ enc.decodeMap[src2[3]],
); ok {
binary.BigEndian.PutUint32(dst[n:], dn)
n += 3