diff --git a/lib/decimal/decimal.go b/lib/decimal/decimal.go index d356e6002..24701be9e 100644 --- a/lib/decimal/decimal.go +++ b/lib/decimal/decimal.go @@ -5,6 +5,7 @@ import ( "sync" "github.com/VictoriaMetrics/VictoriaMetrics/lib/fastnum" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // CalibrateScale calibrates a and b with the corresponding exponents ae, be @@ -81,29 +82,17 @@ var decimalMultipliers = []int64{1e0, 1e1, 1e2, 1e3, 1e4, 1e5, 1e6, 1e7, 1e8, 1e // ExtendFloat64sCapacity extends dst capacity to hold additionalItems // and returns the extended dst. func ExtendFloat64sCapacity(dst []float64, additionalItems int) []float64 { - dstLen := len(dst) - if n := dstLen + additionalItems - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]float64, n)...) - } - return dst[:dstLen] + return slicesutil.ExtendCapacity(dst, additionalItems) } // ExtendInt64sCapacity extends dst capacity to hold additionalItems // and returns the extended dst. func ExtendInt64sCapacity(dst []int64, additionalItems int) []int64 { - dstLen := len(dst) - if n := dstLen + additionalItems - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]int64, n)...) - } - return dst[:dstLen] + return slicesutil.ExtendCapacity(dst, additionalItems) } func extendInt16sCapacity(dst []int16, additionalItems int) []int16 { - dstLen := len(dst) - if n := dstLen + additionalItems - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]int16, n)...) - } - return dst[:dstLen] + return slicesutil.ExtendCapacity(dst, additionalItems) } // AppendDecimalToFloat converts each item in va to f=v*10^e, appends it diff --git a/lib/encoding/float.go b/lib/encoding/float.go index b703118d4..17fc9fa32 100644 --- a/lib/encoding/float.go +++ b/lib/encoding/float.go @@ -2,6 +2,8 @@ package encoding import ( "sync" + + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // GetFloat64s returns a slice of float64 values with the given size. @@ -14,9 +16,7 @@ func GetFloat64s(size int) *Float64s { v = &Float64s{} } a := v.(*Float64s) - if n := len(a.A) + size - cap(a.A); n > 0 { - a.A = append(a.A[:cap(a.A)], make([]float64, n)...) - } + a.A = slicesutil.ExtendCapacity(a.A, size) a.A = a.A[:size] return a } diff --git a/lib/encoding/int.go b/lib/encoding/int.go index 66a816e41..0b8d11a69 100644 --- a/lib/encoding/int.go +++ b/lib/encoding/int.go @@ -4,6 +4,8 @@ import ( "encoding/binary" "fmt" "sync" + + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // MarshalUint16 appends marshaled v to dst and returns the result. @@ -517,9 +519,7 @@ func GetInt64s(size int) *Int64s { } } is := v.(*Int64s) - if n := len(is.A) + size - cap(is.A); n > 0 { - is.A = append(is.A[:cap(is.A)], make([]int64, n)...) - } + is.A = slicesutil.ExtendCapacity(is.A, size) is.A = is.A[:size] return is } @@ -546,9 +546,7 @@ func GetUint64s(size int) *Uint64s { } } is := v.(*Uint64s) - if n := len(is.A) + size - cap(is.A); n > 0 { - is.A = append(is.A[:cap(is.A)], make([]uint64, n)...) - } + is.A = slicesutil.ExtendCapacity(is.A, size) is.A = is.A[:size] return is } @@ -575,9 +573,7 @@ func GetUint32s(size int) *Uint32s { } } is := v.(*Uint32s) - if n := len(is.A) + size - cap(is.A); n > 0 { - is.A = append(is.A[:cap(is.A)], make([]uint32, n)...) - } + is.A = slicesutil.ExtendCapacity(is.A, size) is.A = is.A[:size] return is } diff --git a/lib/encoding/nearest_delta2.go b/lib/encoding/nearest_delta2.go index 00c185a5d..3e3013cf4 100644 --- a/lib/encoding/nearest_delta2.go +++ b/lib/encoding/nearest_delta2.go @@ -4,6 +4,7 @@ import ( "fmt" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // marshalInt64NearestDelta2 encodes src using `nearest delta2` encoding @@ -70,9 +71,7 @@ func unmarshalInt64NearestDelta2(dst []int64, src []byte, firstValue int64, item } dstLen := len(dst) - if n := dstLen + itemsCount - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]int64, n)...) - } + dst = slicesutil.ExtendCapacity(dst, itemsCount) dst = dst[:dstLen+itemsCount] as := dst[dstLen:] diff --git a/lib/logstorage/bitmap.go b/lib/logstorage/bitmap.go index 027622012..ea962fb2f 100644 --- a/lib/logstorage/bitmap.go +++ b/lib/logstorage/bitmap.go @@ -5,6 +5,7 @@ import ( "sync" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) func getBitmap(bitsLen int) *bitmap { @@ -46,9 +47,7 @@ func (bm *bitmap) copyFrom(src *bitmap) { func (bm *bitmap) init(bitsLen int) { a := bm.a wordsLen := (bitsLen + 63) / 64 - if n := len(a) + wordsLen - cap(a); n > 0 { - a = append(a[:cap(a)], make([]uint64, n)...) - } + a = slicesutil.ExtendCapacity(a, wordsLen) a = a[:wordsLen] bm.a = a bm.bitsLen = bitsLen diff --git a/lib/logstorage/block.go b/lib/logstorage/block.go index 250db40ba..77d3d7595 100644 --- a/lib/logstorage/block.go +++ b/lib/logstorage/block.go @@ -8,6 +8,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // block represents a block of log entries. @@ -142,13 +143,9 @@ func (c *column) canStoreInConstColumn() bool { } func (c *column) resizeValues(valuesLen int) []string { - values := c.values - if n := len(values) + valuesLen - cap(values); n > 0 { - values = append(values[:cap(values)], make([]string, n)...) - } - values = values[:valuesLen] - c.values = values - return values + values := slicesutil.ExtendCapacity(c.values, valuesLen) + c.values = values[:valuesLen] + return c.values } // mustWriteTo writes c to sw and updates ch accordingly. @@ -370,13 +367,9 @@ func (b *block) extendColumns() *column { } func (b *block) resizeColumns(columnsLen int) []column { - cs := b.columns - if n := len(cs) + columnsLen - cap(cs); n > 0 { - cs = append(cs[:cap(cs)], make([]column, n)...) - } - cs = cs[:columnsLen] - b.columns = cs - return cs + cs := slicesutil.ExtendCapacity(b.columns, columnsLen) + b.columns = cs[:columnsLen] + return b.columns } func (b *block) sortColumnsByName() { diff --git a/lib/logstorage/block_data.go b/lib/logstorage/block_data.go index 1693a49f9..feff014e8 100644 --- a/lib/logstorage/block_data.go +++ b/lib/logstorage/block_data.go @@ -4,6 +4,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil" "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // blockData contains packed data for a single block. @@ -52,13 +53,9 @@ func (bd *blockData) reset() { } func (bd *blockData) resizeColumnsData(columnsDataLen int) []columnData { - cds := bd.columnsData - if n := len(cds) + columnsDataLen - cap(cds); n > 0 { - cds = append(cds[:cap(cds)], make([]columnData, n)...) - } - cds = cds[:columnsDataLen] - bd.columnsData = cds - return cds + cds := slicesutil.ExtendCapacity(bd.columnsData, columnsDataLen) + bd.columnsData = cds[:columnsDataLen] + return bd.columnsData } // copyFrom copies src to bd. diff --git a/lib/logstorage/block_header.go b/lib/logstorage/block_header.go index ec14caf2f..921ecf705 100644 --- a/lib/logstorage/block_header.go +++ b/lib/logstorage/block_header.go @@ -8,6 +8,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil" "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // blockHeader contains information about a single block. @@ -263,23 +264,15 @@ func (csh *columnsHeader) getColumnHeader(name string) *columnHeader { } func (csh *columnsHeader) resizeConstColumns(columnsLen int) []Field { - ccs := csh.constColumns - if n := len(ccs) + columnsLen - cap(ccs); n > 0 { - ccs = append(ccs[:cap(ccs)], make([]Field, n)...) - } - ccs = ccs[:columnsLen] - csh.constColumns = ccs - return ccs + ccs := slicesutil.ExtendCapacity(csh.constColumns, columnsLen) + csh.constColumns = ccs[:columnsLen] + return csh.constColumns } func (csh *columnsHeader) resizeColumnHeaders(columnHeadersLen int) []columnHeader { - chs := csh.columnHeaders - if n := len(chs) + columnHeadersLen - cap(chs); n > 0 { - chs = append(chs[:cap(chs)], make([]columnHeader, n)...) - } - chs = chs[:columnHeadersLen] - csh.columnHeaders = chs - return chs + chs := slicesutil.ExtendCapacity(csh.columnHeaders, columnHeadersLen) + csh.columnHeaders = chs[:columnHeadersLen] + return csh.columnHeaders } func (csh *columnsHeader) marshal(dst []byte) []byte { diff --git a/lib/logstorage/bloomfilter.go b/lib/logstorage/bloomfilter.go index 9b256154d..c260b24b6 100644 --- a/lib/logstorage/bloomfilter.go +++ b/lib/logstorage/bloomfilter.go @@ -5,9 +5,11 @@ import ( "sync" "unsafe" + "github.com/cespare/xxhash/v2" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil" "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" - "github.com/cespare/xxhash/v2" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // bloomFilterHashesCount is the number of different hashes to use for bloom filter. @@ -53,10 +55,7 @@ func (bf *bloomFilter) unmarshal(src []byte) error { } bf.reset() wordsCount := len(src) / 8 - bits := bf.bits - if n := len(bits) + wordsCount - cap(bits); n > 0 { - bits = append(bits[:cap(bits)], make([]uint64, n)...) - } + bits := slicesutil.ExtendCapacity(bf.bits, wordsCount) bits = bits[:wordsCount] for i := range bits { bits[i] = encoding.UnmarshalUint64(src) @@ -70,10 +69,7 @@ func (bf *bloomFilter) unmarshal(src []byte) error { func (bf *bloomFilter) mustInit(tokens []string) { bitsCount := len(tokens) * bloomFilterBitsPerItem wordsCount := (bitsCount + 63) / 64 - bits := bf.bits - if n := len(bits) + wordsCount - cap(bits); n > 0 { - bits = append(bits[:cap(bits)], make([]uint64, n)...) - } + bits := slicesutil.ExtendCapacity(bf.bits, wordsCount) bits = bits[:wordsCount] bloomFilterAdd(bits, tokens) bf.bits = bits diff --git a/lib/logstorage/storage_search.go b/lib/logstorage/storage_search.go index 8d3a05b51..e24b9c589 100644 --- a/lib/logstorage/storage_search.go +++ b/lib/logstorage/storage_search.go @@ -9,6 +9,7 @@ import ( "sync/atomic" "github.com/VictoriaMetrics/VictoriaMetrics/lib/cgroup" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // genericSearchOptions contain options used for search. @@ -197,11 +198,7 @@ func getEmptyStrings(rowsCount int) []string { return values } values := *p - if n := len(values) + rowsCount - cap(values); n > 0 { - valuesNew := append(values[:cap(values)], make([]string, n)...) - emptyStrings.Store(&valuesNew) - values = valuesNew - } + values = slicesutil.ExtendCapacity(values, rowsCount) return values[:rowsCount] } diff --git a/lib/mergeset/block_header.go b/lib/mergeset/block_header.go index a957427ae..795492357 100644 --- a/lib/mergeset/block_header.go +++ b/lib/mergeset/block_header.go @@ -7,6 +7,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) type blockHeader struct { @@ -160,9 +161,7 @@ func unmarshalBlockHeadersNoCopy(dst []blockHeader, src []byte, blockHeadersCoun logger.Panicf("BUG: blockHeadersCount must be greater than 0; got %d", blockHeadersCount) } dstLen := len(dst) - if n := dstLen + blockHeadersCount - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]blockHeader, n)...) - } + dst = slicesutil.ExtendCapacity(dst, blockHeadersCount) dst = dst[:dstLen+blockHeadersCount] for i := 0; i < blockHeadersCount; i++ { tail, err := dst[dstLen+i].UnmarshalNoCopy(src) diff --git a/lib/mergeset/encoding.go b/lib/mergeset/encoding.go index 9d4a01c8c..da3f2a2f6 100644 --- a/lib/mergeset/encoding.go +++ b/lib/mergeset/encoding.go @@ -12,6 +12,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil" "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // Item represents a single item for storing in a mergeset. @@ -412,9 +413,7 @@ func (ib *inmemoryBlock) UnmarshalData(sb *storageBlock, firstItem, commonPrefix // since the data isn't going to be resized after unmarshaling. // This may save memory for caching the unmarshaled block. data := bytesutil.ResizeNoCopyNoOverallocate(ib.data, dataLen) - if n := len(ib.items) + int(itemsCount) - cap(ib.items); n > 0 { - ib.items = append(ib.items[:cap(ib.items)], make([]Item, n)...) - } + ib.items = slicesutil.ExtendCapacity(ib.items, int(itemsCount)) ib.items = ib.items[:itemsCount] data = append(data[:0], firstItem...) items := ib.items diff --git a/lib/mergeset/table_search.go b/lib/mergeset/table_search.go index 364162287..412fbd838 100644 --- a/lib/mergeset/table_search.go +++ b/lib/mergeset/table_search.go @@ -7,6 +7,7 @@ import ( "io" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // TableSearch is a reusable cursor used for searching in the Table. @@ -71,9 +72,7 @@ func (ts *TableSearch) Init(tb *Table) { ts.pws = ts.tb.getParts(ts.pws[:0]) // Initialize the psPool. - if n := len(ts.psPool) + len(ts.pws) - cap(ts.psPool); n > 0 { - ts.psPool = append(ts.psPool[:cap(ts.psPool)], make([]partSearch, n)...) - } + ts.psPool = slicesutil.ExtendCapacity(ts.psPool, len(ts.pws)) ts.psPool = ts.psPool[:len(ts.pws)] for i, pw := range ts.pws { ts.psPool[i].Init(pw.p) diff --git a/lib/prompbmarshal/util.go b/lib/prompbmarshal/util.go index fe65b08ce..cdfcc5862 100644 --- a/lib/prompbmarshal/util.go +++ b/lib/prompbmarshal/util.go @@ -2,15 +2,15 @@ package prompbmarshal import ( "fmt" + + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // MarshalProtobuf marshals wr to dst and returns the result. func (wr *WriteRequest) MarshalProtobuf(dst []byte) []byte { size := wr.Size() dstLen := len(dst) - if n := dstLen + size - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]byte, n)...) - } + dst = slicesutil.ExtendCapacity(dst, size) dst = dst[:dstLen+size] n, err := wr.MarshalToSizedBuffer(dst[dstLen:]) if err != nil { diff --git a/lib/storage/block_header.go b/lib/storage/block_header.go index 6bade6216..f7689f5f1 100644 --- a/lib/storage/block_header.go +++ b/lib/storage/block_header.go @@ -7,6 +7,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // blockHeader is a header for a time series block. @@ -252,10 +253,7 @@ func unmarshalBlockHeaders(dst []blockHeader, src []byte, blockHeadersCount int) logger.Panicf("BUG: blockHeadersCount must be greater than zero; got %d", blockHeadersCount) } dstLen := len(dst) - if n := dstLen + blockHeadersCount - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]blockHeader, n)...) - dst = dst[:dstLen] - } + dst = slicesutil.ExtendCapacity(dst, blockHeadersCount) var bh blockHeader for len(src) > 0 { tmp, err := bh.Unmarshal(src) diff --git a/lib/storage/metric_name.go b/lib/storage/metric_name.go index 6c980ad3d..85bff0e1d 100644 --- a/lib/storage/metric_name.go +++ b/lib/storage/metric_name.go @@ -15,6 +15,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" "github.com/VictoriaMetrics/VictoriaMetrics/lib/prompb" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) const ( @@ -702,9 +703,7 @@ func (mn *MetricName) sortTags() { } cts := getCanonicalTags() - if n := len(cts.tags) + len(mn.Tags) - cap(cts.tags); n > 0 { - cts.tags = append(cts.tags[:cap(cts.tags)], make([]canonicalTag, n)...) - } + cts.tags = slicesutil.ExtendCapacity(cts.tags, len(mn.Tags)) dst := cts.tags[:len(mn.Tags)] for i := range mn.Tags { tag := &mn.Tags[i] @@ -775,9 +774,7 @@ func (ts *canonicalTagsSort) Swap(i, j int) { func copyTags(dst, src []Tag) []Tag { dstLen := len(dst) - if n := dstLen + len(src) - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]Tag, n)...) - } + dst = slicesutil.ExtendCapacity(dst, len(src)) dst = dst[:dstLen+len(src)] for i := range src { dst[dstLen+i].copyFrom(&src[i]) diff --git a/lib/storage/partition_search.go b/lib/storage/partition_search.go index b67342935..e86305fa0 100644 --- a/lib/storage/partition_search.go +++ b/lib/storage/partition_search.go @@ -6,6 +6,7 @@ import ( "io" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // partitionSearch represents a search in the partition. @@ -83,9 +84,7 @@ func (pts *partitionSearch) Init(pt *partition, tsids []TSID, tr TimeRange) { pts.pws = pt.GetParts(pts.pws[:0], true) // Initialize psPool. - if n := len(pts.psPool) + len(pts.pws) - cap(pts.psPool); n > 0 { - pts.psPool = append(pts.psPool[:cap(pts.psPool)], make([]partSearch, n)...) - } + pts.psPool = slicesutil.ExtendCapacity(pts.psPool, len(pts.pws)) pts.psPool = pts.psPool[:len(pts.pws)] for i, pw := range pts.pws { pts.psPool[i].Init(pw.p, tsids, tr) diff --git a/lib/storage/search.go b/lib/storage/search.go index 6b622a182..45d535e28 100644 --- a/lib/storage/search.go +++ b/lib/storage/search.go @@ -10,6 +10,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/fasttime" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" "github.com/VictoriaMetrics/VictoriaMetrics/lib/querytracer" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" "github.com/VictoriaMetrics/VictoriaMetrics/lib/stringsutil" ) @@ -413,9 +414,7 @@ func (sq *SearchQuery) Unmarshal(src []byte) ([]byte, error) { if err != nil { return src, fmt.Errorf("cannot unmarshal the count of TagFilterss: %w", err) } - if n := len(sq.TagFilterss) + int(tfssCount) - cap(sq.TagFilterss); n > 0 { - sq.TagFilterss = append(sq.TagFilterss[:cap(sq.TagFilterss)], make([][]TagFilter, n)...) - } + sq.TagFilterss = slicesutil.ExtendCapacity(sq.TagFilterss, int(tfssCount)) sq.TagFilterss = sq.TagFilterss[:tfssCount] src = tail @@ -427,9 +426,7 @@ func (sq *SearchQuery) Unmarshal(src []byte) ([]byte, error) { src = tail tagFilters := sq.TagFilterss[i] - if n := len(tagFilters) + int(tfsCount) - cap(tagFilters); n > 0 { - tagFilters = append(tagFilters[:cap(tagFilters)], make([]TagFilter, n)...) - } + tagFilters = slicesutil.ExtendCapacity(tagFilters, int(tfsCount)) tagFilters = tagFilters[:tfsCount] for j := 0; j < int(tfsCount); j++ { tail, err := tagFilters[j].Unmarshal(src) diff --git a/lib/storage/table_search.go b/lib/storage/table_search.go index 4eade30f5..955ba9d83 100644 --- a/lib/storage/table_search.go +++ b/lib/storage/table_search.go @@ -7,6 +7,7 @@ import ( "github.com/VictoriaMetrics/VictoriaMetrics/lib/fasttime" "github.com/VictoriaMetrics/VictoriaMetrics/lib/logger" + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // tableSearch performs searches in the table. @@ -84,9 +85,7 @@ func (ts *tableSearch) Init(tb *table, tsids []TSID, tr TimeRange) { ts.ptws = tb.GetPartitions(ts.ptws[:0]) // Initialize the ptsPool. - if n := len(ts.ptsPool) + len(ts.ptws) - cap(ts.ptsPool); n > 0 { - ts.ptsPool = append(ts.ptsPool[:cap(ts.ptsPool)], make([]partitionSearch, n)...) - } + ts.ptsPool = slicesutil.ExtendCapacity(ts.ptsPool, len(ts.ptws)) ts.ptsPool = ts.ptsPool[:len(ts.ptws)] for i, ptw := range ts.ptws { ts.ptsPool[i].Init(ptw.pt, tsids, tr) diff --git a/lib/uint64set/uint64set.go b/lib/uint64set/uint64set.go index b4b8014b7..d524e8788 100644 --- a/lib/uint64set/uint64set.go +++ b/lib/uint64set/uint64set.go @@ -6,6 +6,8 @@ import ( "sync" "sync/atomic" "unsafe" + + "github.com/VictoriaMetrics/VictoriaMetrics/lib/slicesutil" ) // Set is a fast set for uint64. @@ -226,12 +228,8 @@ func (s *Set) AppendTo(dst []uint64) []uint64 { } // pre-allocate memory for dst - dstLen := len(dst) sLen := s.Len() - if n := dstLen + sLen - cap(dst); n > 0 { - dst = append(dst[:cap(dst)], make([]uint64, n)...) - dst = dst[:dstLen] - } + dst = slicesutil.ExtendCapacity(dst, sLen) s.sort() for i := range s.buckets { dst = s.buckets[i].appendTo(dst)