mirror of https://github.com/v2ray/v2ray-core
				
				
				
			
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
| package buf
 | |
| 
 | |
| import (
 | |
| 	"sync"
 | |
| )
 | |
| 
 | |
| const (
 | |
| 	// Size of a regular buffer.
 | |
| 	Size = 2 * 1024
 | |
| )
 | |
| 
 | |
| func createAllocFunc(size uint32) func() interface{} {
 | |
| 	return func() interface{} {
 | |
| 		return make([]byte, size)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // The following parameters controls the size of buffer pools.
 | |
| // There are numPools pools. Starting from 2k size, the size of each pool is sizeMulti of the previous one.
 | |
| // Package buf is guaranteed to not use buffers larger than the largest pool.
 | |
| // Other packets may use larger buffers.
 | |
| const (
 | |
| 	numPools  = 5
 | |
| 	sizeMulti = 4
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	pool      [numPools]sync.Pool
 | |
| 	poolSize  [numPools]uint32
 | |
| 	largeSize uint32
 | |
| )
 | |
| 
 | |
| func init() {
 | |
| 	size := uint32(Size)
 | |
| 	for i := 0; i < numPools; i++ {
 | |
| 		pool[i] = sync.Pool{
 | |
| 			New: createAllocFunc(size),
 | |
| 		}
 | |
| 		poolSize[i] = size
 | |
| 		largeSize = size
 | |
| 		size *= sizeMulti
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func newBytes(size uint32) []byte {
 | |
| 	for idx, ps := range poolSize {
 | |
| 		if size <= ps {
 | |
| 			return pool[idx].Get().([]byte)
 | |
| 		}
 | |
| 	}
 | |
| 	return make([]byte, size)
 | |
| }
 | |
| 
 | |
| func freeBytes(b []byte) {
 | |
| 	size := uint32(cap(b))
 | |
| 	b = b[0:cap(b)]
 | |
| 	for i := numPools - 1; i >= 0; i-- {
 | |
| 		if size >= poolSize[i] {
 | |
| 			pool[i].Put(b)
 | |
| 			return
 | |
| 		}
 | |
| 	}
 | |
| }
 |