新增gmap写入性能基准测试代码

This commit is contained in:
John
2018-02-28 15:32:52 +08:00
parent 77d570721c
commit 40196e1413
2 changed files with 103 additions and 15 deletions

View File

@ -0,0 +1,56 @@
// Copyright 2017 gf Author(https://gitee.com/johng/gf). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://gitee.com/johng/gf.
// go test *.go -bench=".*"
package gmap_test
import (
"testing"
"gitee.com/johng/gf/g/container/gmap"
"sync"
)
var m1 = gmap.NewIntIntMap()
var m2 = sync.Map{}
func BenchmarkGmapSet(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Set(i, i)
}
}
func BenchmarkSyncmapSet(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Store(i, i)
}
}
func BenchmarkGmapGet(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Get(i)
}
}
func BenchmarkSyncmapGet(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Load(i)
}
}
func BenchmarkGmapRemove(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Remove(i)
}
}
func BenchmarkSyncmapRmove(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Delete(i)
}
}

View File

@ -11,46 +11,78 @@ package gmap_test
import (
"testing"
"gitee.com/johng/gf/g/container/gmap"
"sync"
"strconv"
)
var m1 = gmap.NewIntIntMap()
var m2 = sync.Map{}
var ibm = gmap.NewIntBoolMap()
var iim = gmap.NewIntIntMap()
var iifm = gmap.NewIntInterfaceMap()
var ism = gmap.NewIntStringMap()
var ififm = gmap.NewInterfaceInterfaceMap()
var sbm = gmap.NewStringBoolMap()
var sim = gmap.NewStringIntMap()
var sifm = gmap.NewStringInterfaceMap()
var ssm = gmap.NewStringStringMap()
var uifm = gmap.NewUintInterfaceMap()
func BenchmarkGmapSet(b *testing.B) {
func BenchmarkIntBoolMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Set(i, i)
ibm.Set(i, true)
}
}
func BenchmarkSyncmapSet(b *testing.B) {
func BenchmarkIntIntMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Store(i, i)
iim.Set(i, i)
}
}
func BenchmarkGmapGet(b *testing.B) {
func BenchmarkIntInterfaceMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Get(i)
iifm.Set(i, i)
}
}
func BenchmarkSyncmapGet(b *testing.B) {
func BenchmarkIntStringMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Load(i)
ism.Set(i, strconv.Itoa(i))
}
}
func BenchmarkGmapRemove(b *testing.B) {
func BenchmarkInterfaceInterfaceMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m1.Remove(i)
ififm.Set(i, i)
}
}
func BenchmarkSyncmapRmove(b *testing.B) {
func BenchmarkStringBoolMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
m2.Delete(i)
sbm.Set(strconv.Itoa(i), true)
}
}
func BenchmarkStringIntMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
sim.Set(strconv.Itoa(i), i)
}
}
func BenchmarkStringInterfaceMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
sifm.Set(strconv.Itoa(i), i)
}
}
func BenchmarkStringStringMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
ssm.Set(strconv.Itoa(i), strconv.Itoa(i))
}
}
func BenchmarkUintInterfaceMap_Set(b *testing.B) {
for i := 0; i < b.N; i++ {
uifm.Set(uint(i), i)
}
}