1 Star 0 Fork 6

冲击 / netpoll

forked from CloudWeGo / netpoll 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
fd_operator_cache_test.go 1.36 KB
一键复制 编辑 原始数据 按行查看 历史
Hchen 提交于 2021-06-23 16:24 . release: netpoll v0.0.1
// Copyright 2021 CloudWeGo Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package netpoll
import (
"runtime"
"testing"
)
// go test -v -gcflags=-d=checkptr -run=TestPersistFDOperator
func TestPersistFDOperator(t *testing.T) {
// init
size := 1000
var ops = make([]*FDOperator, size)
for i := 0; i < size; i++ {
op := allocop()
op.FD = i
ops[i] = op
}
// gc
for i := 0; i < 4; i++ {
runtime.GC()
}
// check alloc
for i := range ops {
Equal(t, ops[i].FD, i)
freeop(ops[i])
}
}
func BenchmarkPersistFDOperator1(b *testing.B) {
b.ReportAllocs()
b.ResetTimer()
for i := 0; i < b.N; i++ {
op := allocop()
freeop(op)
}
}
func BenchmarkPersistFDOperator2(b *testing.B) {
// benchmark
b.ReportAllocs()
b.SetParallelism(128)
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
op := allocop()
freeop(op)
}
})
}
1
https://gitee.com/1273640670/netpoll.git
git@gitee.com:1273640670/netpoll.git
1273640670
netpoll
netpoll
develop

搜索帮助