Skip to content

Commit 3466e57

Browse files
thepuddsgopherbot
authored andcommitted
fmt: avoid reflect.Value.Slice to help escape analysis
This is part of a series of CLs that aim to reduce how often interface arguments escape for the print functions in fmt. Prior to this change, one reason arguments escape is because printValue calls reflect.Value.Slice, which causes its value argument to escape (though at this CL, that is shrouded in the fmt escape analysis logs by other printValue escape reasons). This CL avoids that usage by calling f.Bytes instead, which is possible because we know f is a slice of bytes or an addressable array of bytes. Arguments still escape for other reasons. Change-Id: Ic3f064117a364007e1dd3197cef9d641abbf784a Reviewed-on: https://go-review.googlesource.com/c/go/+/524940 TryBot-Result: Gopher Robot <[email protected]> Reviewed-by: Ian Lance Taylor <[email protected]> Reviewed-by: Matthew Dempsky <[email protected]> Auto-Submit: Ian Lance Taylor <[email protected]> Run-TryBot: t hepudds <[email protected]>
1 parent a2f28a4 commit 3466e57

File tree

1 file changed

+1
-3
lines changed

1 file changed

+1
-3
lines changed

src/fmt/print.go

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -872,10 +872,8 @@ func (p *pp) printValue(value reflect.Value, verb rune, depth int) {
872872
t := f.Type()
873873
if t.Elem().Kind() == reflect.Uint8 {
874874
var bytes []byte
875-
if f.Kind() == reflect.Slice {
875+
if f.Kind() == reflect.Slice || f.CanAddr() {
876876
bytes = f.Bytes()
877-
} else if f.CanAddr() {
878-
bytes = f.Slice(0, f.Len()).Bytes()
879877
} else {
880878
// We have an array, but we cannot Slice() a non-addressable array,
881879
// so we build a slice by hand. This is a rare case but it would be nice

0 commit comments

Comments
 (0)