]> Cypherpunks repositories - gostls13.git/commit
reflect: make all flag.mustBe* methods inlinable
authorDaniel Martí <mvdan@mvdan.cc>
Sat, 9 Mar 2019 18:09:10 +0000 (18:09 +0000)
committerDaniel Martí <mvdan@mvdan.cc>
Sat, 9 Mar 2019 19:50:24 +0000 (19:50 +0000)
commit788e038e5d5fcdc1cc44ec9af1885db55a19977c
treea8b1ff3a111e8ec3987071eae6cb1297a83d0749
parentcc5dc00150725fec3933f7d4c571da94978b7978
reflect: make all flag.mustBe* methods inlinable

mustBe was barely over budget, so manually inlining the first flag.kind
call is enough. Add a TODO to reverse that in the future, once the
compiler gets better.

mustBeExported and mustBeAssignable were over budget by a larger amount,
so add slow path functions instead. This is the same strategy used in
the sync package for common methods like Once.Do, for example.

Lots of exported reflect.Value methods call these assert-like unexported
methods, so avoiding the function call overhead in the common case does
shave off a percent from most exported APIs.

Finally, add the methods to TestIntendedInlining.

While at it, replace a couple of uses of the 0 Kind with its descriptive
name, Invalid.

name     old time/op    new time/op    delta
Call-8     68.0ns ± 1%    66.8ns ± 1%  -1.81%  (p=0.000 n=10+9)
PtrTo-8    8.00ns ± 2%    7.83ns ± 0%  -2.19%  (p=0.000 n=10+9)

Updates #7818.

Change-Id: Ic1603b640519393f6b50dd91ec3767753eb9e761
Reviewed-on: https://go-review.googlesource.com/c/go/+/166462
Run-TryBot: Daniel Martí <mvdan@mvdan.cc>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
src/cmd/compile/internal/gc/inl_test.go
src/reflect/value.go