Spaces:
Running
Running
File size: 1,398 Bytes
b110593 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
// _ _
// __ _____ __ ___ ___ __ _| |_ ___
// \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \
// \ V V / __/ (_| |\ V /| | (_| | || __/
// \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___|
//
// Copyright © 2016 - 2024 Weaviate B.V. All rights reserved.
//
// CONTACT: [email protected]
//
package storobj
import "sync"
func newBufferPool(initialSize int) *bufferPool {
return &bufferPool{
pool: sync.Pool{
New: func() any {
// initialize with len=0 to make sure we get a consistent result
// whether it's a new or used buffer. Every buffer will always have
// len=0 and cap>=initialSize
return make([]byte, 0, initialSize)
},
},
}
}
type bufferPool struct {
pool sync.Pool
}
func (b *bufferPool) Get() []byte {
buf := b.pool.Get().([]byte)
return buf
}
func (b *bufferPool) Put(buf []byte) {
// make sure the length is reset before putting it back into the pool. This
// way all buffers will always have len=0, either because they are brand-new
// or because they have been reset.
buf = buf[:0]
//nolint:staticcheck // I disagree with the linter, this doesn't need to be a
//pointer. Even if we copy the slicestruct header, the backing array is
//what's allocation-heavy and that will be reused. The profiles in the PR
//description prove this.
b.pool.Put(buf)
}
|