aboutsummaryrefslogtreecommitdiff
path: root/src/reflect
diff options
context:
space:
mode:
authorSergei Zagurskii <gvozdoder@gmail.com>2019-05-22 17:00:34 +0300
committerBrad Fitzpatrick <bradfitz@golang.org>2019-08-27 16:44:22 +0000
commit8057c0887f89701b3091755d986b534fd8a50fc7 (patch)
treebfa6d2c398719b4def1a2c443b0ca589bda83a20 /src/reflect
parentdca0d03b9c9ad20de743bd8ac4cd4b2b466713a3 (diff)
downloadgo-8057c0887f89701b3091755d986b534fd8a50fc7.tar.gz
go-8057c0887f89701b3091755d986b534fd8a50fc7.zip
reflect: optimize directlyAssignable to avoid rtype.Name call
directlyAssignable invoked rtype.Name() just to compare its result to empty string. We really only need to check whether rtype has name. It can be done much cheaper, by checking tflagNamed. Benchmark: https://play.golang.org/p/V2BzESPuf2w name old time/op new time/op delta DirectlyAssignable-12 32.7ns ± 6% 6.6ns ± 6% -79.80% (p=0.008 n=5+5) Fixes #32186 Change-Id: I1a2a167dbfddf319fba3015cb6a011bf010f99a8 Reviewed-on: https://go-review.googlesource.com/c/go/+/178518 Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
Diffstat (limited to 'src/reflect')
-rw-r--r--src/reflect/type.go8
1 files changed, 6 insertions, 2 deletions
diff --git a/src/reflect/type.go b/src/reflect/type.go
index 7aafc505bd..4afe634bbf 100644
--- a/src/reflect/type.go
+++ b/src/reflect/type.go
@@ -871,8 +871,12 @@ func hasPrefix(s, prefix string) bool {
return len(s) >= len(prefix) && s[:len(prefix)] == prefix
}
+func (t *rtype) hasName() bool {
+ return t.tflag&tflagNamed != 0
+}
+
func (t *rtype) Name() string {
- if t.tflag&tflagNamed == 0 {
+ if !t.hasName() {
return ""
}
s := t.String()
@@ -1563,7 +1567,7 @@ func directlyAssignable(T, V *rtype) bool {
// Otherwise at least one of T and V must not be defined
// and they must have the same kind.
- if T.Name() != "" && V.Name() != "" || T.Kind() != V.Kind() {
+ if T.hasName() && V.hasName() || T.Kind() != V.Kind() {
return false
}