Files
EdgeNode/internal/utils/byte_pool_test.go

94 lines
1.5 KiB
Go
Raw Normal View History

2024-01-22 11:21:19 +08:00
package utils_test
2020-09-26 08:07:07 +08:00
import (
2024-01-22 11:21:19 +08:00
"bytes"
"github.com/TeaOSLab/EdgeNode/internal/utils"
2020-09-26 08:07:07 +08:00
"runtime"
2022-08-07 11:12:29 +08:00
"sync"
2020-09-26 08:07:07 +08:00
"testing"
)
2021-12-19 11:32:26 +08:00
func TestBytePool_Memory(t *testing.T) {
var stat1 = &runtime.MemStats{}
runtime.ReadMemStats(stat1)
2024-01-22 11:21:19 +08:00
var pool = utils.NewBytePool(32 * 1024)
2021-12-19 11:32:26 +08:00
for i := 0; i < 20480; i++ {
pool.Put(make([]byte, 32*1024))
}
//pool.Purge()
//time.Sleep(60 * time.Second)
runtime.GC()
var stat2 = &runtime.MemStats{}
runtime.ReadMemStats(stat2)
2022-08-07 11:12:29 +08:00
t.Log((stat2.HeapInuse-stat1.HeapInuse)/1024/1024, "MB,")
2021-12-19 11:32:26 +08:00
}
2020-09-26 08:07:07 +08:00
func BenchmarkBytePool_Get(b *testing.B) {
runtime.GOMAXPROCS(1)
2024-01-22 11:21:19 +08:00
var pool = utils.NewBytePool(1)
2022-08-07 11:12:29 +08:00
b.ResetTimer()
2020-09-26 08:07:07 +08:00
for i := 0; i < b.N; i++ {
2022-08-07 11:12:29 +08:00
var buf = pool.Get()
2020-09-26 08:07:07 +08:00
_ = buf
pool.Put(buf)
}
2022-08-07 11:12:29 +08:00
}
func BenchmarkBytePool_Get_Parallel(b *testing.B) {
runtime.GOMAXPROCS(1)
2024-01-22 11:21:19 +08:00
var pool = utils.NewBytePool(1024)
2022-08-07 11:12:29 +08:00
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
var buf = pool.Get()
pool.Put(buf)
}
})
}
func BenchmarkBytePool_Get_Sync(b *testing.B) {
runtime.GOMAXPROCS(1)
var pool = &sync.Pool{
New: func() any {
return make([]byte, 1024)
},
}
2023-08-08 11:36:54 +08:00
b.ReportAllocs()
2022-08-07 11:12:29 +08:00
b.ResetTimer()
2020-09-26 08:07:07 +08:00
2022-08-07 11:12:29 +08:00
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
var buf = pool.Get()
pool.Put(buf)
}
})
2020-09-26 08:07:07 +08:00
}
2024-01-22 11:21:19 +08:00
func BenchmarkBytePool_Copy(b *testing.B) {
var data = bytes.Repeat([]byte{'A'}, 8<<10)
var pool = &sync.Pool{
New: func() any {
return make([]byte, 8<<10)
},
}
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
var buf = pool.Get().([]byte)
copy(buf, data)
pool.Put(buf)
}
})
}