mirror of https://github.com/v2ray/v2ray-core
leverage sync.Pool for allocation boost
parent
4773a8f4ae
commit
e0b56528fc
|
@ -1,5 +1,9 @@
|
|||
package alloc
|
||||
|
||||
import (
|
||||
"sync"
|
||||
)
|
||||
|
||||
// Buffer is a recyclable allocation of a byte array. Buffer.Release() recycles
|
||||
// the buffer into an internal buffer pool, in order to recreate a buffer more
|
||||
// quickly.
|
||||
|
@ -69,15 +73,16 @@ func (b *Buffer) Write(data []byte) (int, error) {
|
|||
}
|
||||
|
||||
type bufferPool struct {
|
||||
chain chan []byte
|
||||
bufferSize int
|
||||
buffers2Keep int
|
||||
chain chan []byte
|
||||
allocator *sync.Pool
|
||||
}
|
||||
|
||||
func newBufferPool(bufferSize, poolSize int) *bufferPool {
|
||||
pool := &bufferPool{
|
||||
chain: make(chan []byte, poolSize),
|
||||
bufferSize: bufferSize,
|
||||
chain: make(chan []byte, poolSize),
|
||||
allocator: &sync.Pool{
|
||||
New: func() interface{} { return make([]byte, bufferSize) },
|
||||
},
|
||||
}
|
||||
for i := 0; i < poolSize; i++ {
|
||||
pool.chain <- make([]byte, bufferSize)
|
||||
|
@ -90,7 +95,7 @@ func (p *bufferPool) allocate() *Buffer {
|
|||
select {
|
||||
case b = <-p.chain:
|
||||
default:
|
||||
b = make([]byte, p.bufferSize)
|
||||
b = p.allocator.Get().([]byte)
|
||||
}
|
||||
return &Buffer{
|
||||
head: b,
|
||||
|
@ -103,6 +108,7 @@ func (p *bufferPool) free(buffer *Buffer) {
|
|||
select {
|
||||
case p.chain <- buffer.head:
|
||||
default:
|
||||
p.allocator.Put(buffer.head)
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue