From c220d90e4c223bd5ee2e36aef9f771a95f36ba1e Mon Sep 17 00:00:00 2001 From: Masaaki Goshima Date: Mon, 27 Dec 2021 12:18:30 +0900 Subject: [PATCH] Use MapItem object in Mapslice directly --- internal/encoder/encoder.go | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) diff --git a/internal/encoder/encoder.go b/internal/encoder/encoder.go index 0785ed7..79a3f64 100644 --- a/internal/encoder/encoder.go +++ b/internal/encoder/encoder.go @@ -207,7 +207,7 @@ type MapItem struct { } type Mapslice struct { - Items []*MapItem + Items []MapItem } func (m *Mapslice) Len() int { @@ -253,22 +253,16 @@ type MapContext struct { var mapContextPool = sync.Pool{ New: func() interface{} { - return &MapContext{} + return &MapContext{ + Slice: &Mapslice{}, + } }, } func NewMapContext(mapLen int) *MapContext { ctx := mapContextPool.Get().(*MapContext) - if ctx.Slice == nil { - ctx.Slice = &Mapslice{ - Items: make([]*MapItem, 0, mapLen), - } - } if len(ctx.Slice.Items) < mapLen { - ctx.Slice.Items = make([]*MapItem, mapLen) - for i := 0; i < mapLen; i++ { - ctx.Slice.Items[i] = &MapItem{} - } + ctx.Slice.Items = make([]MapItem, mapLen) } else { ctx.Slice.Items = ctx.Slice.Items[:mapLen] }