2016-08-05 01:47:04 -04:00
|
|
|
package bytepool
|
|
|
|
|
|
|
|
import "sync"
|
|
|
|
|
|
|
|
// BytePool is a cached pool of reusable byte slices.
|
|
|
|
type BytePool struct {
|
|
|
|
sync.Pool
|
|
|
|
}
|
|
|
|
|
2016-09-05 12:30:03 -04:00
|
|
|
// New allocates a new BytePool with slices of equal length and capacity.
|
|
|
|
func New(length int) *BytePool {
|
2016-08-05 01:47:04 -04:00
|
|
|
var bp BytePool
|
|
|
|
bp.Pool.New = func() interface{} {
|
2016-09-05 12:30:03 -04:00
|
|
|
return make([]byte, length, length)
|
2016-08-05 01:47:04 -04:00
|
|
|
}
|
|
|
|
return &bp
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get returns a byte slice from the pool.
|
|
|
|
func (bp *BytePool) Get() []byte {
|
|
|
|
return bp.Pool.Get().([]byte)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Put returns a byte slice to the pool.
|
|
|
|
func (bp *BytePool) Put(b []byte) {
|
2016-08-06 22:43:33 -04:00
|
|
|
b = b[:cap(b)]
|
2016-08-05 01:47:04 -04:00
|
|
|
// Zero out the bytes.
|
2016-08-06 22:43:33 -04:00
|
|
|
// Apparently this specific expression is optimized by the compiler, see
|
|
|
|
// github.com/golang/go/issues/5373.
|
|
|
|
for i := range b {
|
|
|
|
b[i] = 0
|
2016-08-05 01:47:04 -04:00
|
|
|
}
|
|
|
|
bp.Pool.Put(b)
|
|
|
|
}
|