summaryrefslogtreecommitdiff
path: root/test/live2.go
diff options
context:
space:
mode:
authorMartin Möhrmann <moehrmann@google.com>2017-09-02 18:46:59 +0200
committerMartin Möhrmann <moehrmann@google.com>2017-11-02 17:03:45 +0000
commitfbfc2031a673c95700e46ddf56404a0f648fc8a9 (patch)
tree459146de8fc05408a16bde92f1861315ac6151e1 /test/live2.go
parent1e83f883c54a37f637c557287b0ae8062cef3930 (diff)
downloadgo-git-fbfc2031a673c95700e46ddf56404a0f648fc8a9.tar.gz
cmd/compile: specialize map creation for small hint sizes
Handle make(map[any]any) and make(map[any]any, hint) where hint <= BUCKETSIZE special to allow for faster map initialization and to improve binary size by using runtime calls with fewer arguments. Given hint is smaller or equal to BUCKETSIZE in which case overLoadFactor(hint, 0) is false and no buckets would be allocated by makemap: * If hmap needs to be allocated on the stack then only hmap's hash0 field needs to be initialized and no call to makemap is needed. * If hmap needs to be allocated on the heap then a new special makehmap function will allocate hmap and intialize hmap's hash0 field. Reduces size of the godoc by ~36kb. AMD64 name old time/op new time/op delta NewEmptyMap 16.6ns ± 2% 5.5ns ± 2% -66.72% (p=0.000 n=10+10) NewSmallMap 64.8ns ± 1% 56.5ns ± 1% -12.75% (p=0.000 n=9+10) Updates #6853 Change-Id: I624e90da6775afaa061178e95db8aca674f44e9b Reviewed-on: https://go-review.googlesource.com/61190 Run-TryBot: Martin Möhrmann <moehrmann@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Keith Randall <khr@golang.org>
Diffstat (limited to 'test/live2.go')
-rw-r--r--test/live2.go4
1 files changed, 2 insertions, 2 deletions
diff --git a/test/live2.go b/test/live2.go
index 5c5706d225..cc1b0b7acf 100644
--- a/test/live2.go
+++ b/test/live2.go
@@ -23,7 +23,7 @@ type T40 struct {
func newT40() *T40 {
ret := T40{}
- ret.m = make(map[int]int) // ERROR "live at call to makemap: &ret$"
+ ret.m = make(map[int]int, 42) // ERROR "live at call to makemap: &ret$"
return &ret
}
@@ -35,7 +35,7 @@ func bad40() {
func good40() {
ret := T40{}
- ret.m = make(map[int]int) // ERROR "live at call to makemap: .autotmp_[0-9]+ ret$"
+ ret.m = make(map[int]int, 42) // ERROR "live at call to makemap: .autotmp_[0-9]+ ret$"
t := &ret
printnl() // ERROR "live at call to printnl: .autotmp_[0-9]+ ret$"
useT40(t) // ERROR "live at call to useT40: .autotmp_[0-9]+ ret$"