From c2556729acad5d94d8d0d9954a574474eebc8a24 Mon Sep 17 00:00:00 2001 From: guonaihong Date: Sat, 11 Jun 2022 22:51:10 +0800 Subject: [PATCH] =?UTF-8?q?rhashmap=20Get=E6=8E=A5=E5=8F=A3=E6=BB=A1?= =?UTF-8?q?=E8=B6=B3api=E7=BA=A6=E6=9D=9F=20#2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- rhashmap/rhashmap.go | 9 ++++--- rhashmap/rhashmap_bench_test.go | 2 +- rhashmap/rhashmap_test.go | 46 ++++++++++++++++----------------- 3 files changed, 29 insertions(+), 28 deletions(-) diff --git a/rhashmap/rhashmap.go b/rhashmap/rhashmap.go index 5d5f0f5..c5e1831 100644 --- a/rhashmap/rhashmap.go +++ b/rhashmap/rhashmap.go @@ -4,10 +4,11 @@ package rhashmap // https://github.com/redis/redis/blob/unstable/src/dict.c import ( "errors" - "github.com/cespare/xxhash/v2" "math" "reflect" "unsafe" + + "github.com/cespare/xxhash/v2" ) const ( @@ -303,7 +304,7 @@ func sizeMask(exp int8) uint64 { } // 获取 -func (h *HashMap[K, V]) Get(key K) (v V, err error) { +func (h *HashMap[K, V]) GetWithErr(key K) (v V, err error) { if h.Len() == 0 { err = ErrNotFound return @@ -335,8 +336,8 @@ func (h *HashMap[K, V]) Get(key K) (v V, err error) { } // 获取 -func (h *HashMap[K, V]) GetOrZero(key K) (v V) { - v, _ = h.Get(key) +func (h *HashMap[K, V]) Get(key K) (v V) { + v, _ = h.GetWithErr(key) return } diff --git a/rhashmap/rhashmap_bench_test.go b/rhashmap/rhashmap_bench_test.go index 3fd2194..0a2ec81 100644 --- a/rhashmap/rhashmap_bench_test.go +++ b/rhashmap/rhashmap_bench_test.go @@ -34,7 +34,7 @@ func BenchmarkGet(b *testing.B) { b.ResetTimer() for i := 0.0; i < max; i++ { - v := set.GetOrZero(i) + v := set.Get(i) if v != i { panic(fmt.Sprintf("need:%f, got:%f", i, v)) } diff --git a/rhashmap/rhashmap_test.go b/rhashmap/rhashmap_test.go index ac5e8af..2c9eae6 100644 --- a/rhashmap/rhashmap_test.go +++ b/rhashmap/rhashmap_test.go @@ -16,10 +16,10 @@ func Test_SetGet_StringBool(t *testing.T) { hm.Set("ni", true) hm.Set("hao", true) - assert.True(t, hm.GetOrZero("hello")) - assert.True(t, hm.GetOrZero("world")) - assert.True(t, hm.GetOrZero("ni")) - assert.True(t, hm.GetOrZero("hao")) + assert.True(t, hm.Get("hello")) + assert.True(t, hm.Get("world")) + assert.True(t, hm.Get("ni")) + assert.True(t, hm.Get("hao")) } // 1. set get测试 @@ -31,10 +31,10 @@ func Test_SetGet_StringString(t *testing.T) { hm.Set("ni", "ni") hm.Set("hao", "hao") - assert.Equal(t, hm.GetOrZero("hello"), "hello") - assert.Equal(t, hm.GetOrZero("world"), "world") - assert.Equal(t, hm.GetOrZero("ni"), "ni") - assert.Equal(t, hm.GetOrZero("hao"), "hao") + assert.Equal(t, hm.Get("hello"), "hello") + assert.Equal(t, hm.Get("world"), "world") + assert.Equal(t, hm.Get("ni"), "ni") + assert.Equal(t, hm.Get("hao"), "hao") } // 1. set get测试 @@ -46,10 +46,10 @@ func Test_SetGet_IntString(t *testing.T) { hm.Set(3, "ni") hm.Set(4, "hao") - assert.Equal(t, hm.GetOrZero(1), "hello") - assert.Equal(t, hm.GetOrZero(2), "world") - assert.Equal(t, hm.GetOrZero(3), "ni") - assert.Equal(t, hm.GetOrZero(4), "hao") + assert.Equal(t, hm.Get(1), "hello") + assert.Equal(t, hm.Get(2), "world") + assert.Equal(t, hm.Get(3), "ni") + assert.Equal(t, hm.Get(4), "hao") } // 1. set get测试 @@ -60,10 +60,10 @@ func Test_SetGet_IntString_Lazyinit(t *testing.T) { hm.Set(3, "ni") hm.Set(4, "hao") - assert.Equal(t, hm.GetOrZero(1), "hello") - assert.Equal(t, hm.GetOrZero(2), "world") - assert.Equal(t, hm.GetOrZero(3), "ni") - assert.Equal(t, hm.GetOrZero(4), "hao") + assert.Equal(t, hm.Get(1), "hello") + assert.Equal(t, hm.Get(2), "world") + assert.Equal(t, hm.Get(3), "ni") + assert.Equal(t, hm.Get(4), "hao") } // 1. set get测试 @@ -73,7 +73,7 @@ func Test_SetGet_Replace_IntString(t *testing.T) { hm.Set(1, "hello") hm.Set(1, "world") - assert.Equal(t, hm.GetOrZero(1), "world") + assert.Equal(t, hm.Get(1), "world") } // 1. set get测试 @@ -81,11 +81,11 @@ func Test_SetGet_Replace_IntString(t *testing.T) { func Test_SetGet_Zero(t *testing.T) { hm := New[int, int]() for i := 0; i < 10; i++ { - assert.Equal(t, hm.GetOrZero(i), 0) + assert.Equal(t, hm.Get(i), 0) } for i := 0; i < 10; i++ { - v, err := hm.Get(i) + v, err := hm.GetWithErr(i) assert.Error(t, err) assert.Equal(t, v, 0) } @@ -98,10 +98,10 @@ func Test_SetGet_NotFound(t *testing.T) { hm.Set(1, "hello") hm.Set(1, "world") - _, err := hm.Get(3) + _, err := hm.GetWithErr(3) assert.Error(t, err) - assert.Equal(t, hm.GetOrZero(1), "world") + assert.Equal(t, hm.Get(1), "world") } // 1. set get测试 @@ -114,10 +114,10 @@ func Test_SetGet_Rehashing(t *testing.T) { hm.Set(4, "world") hm.Set(5, "world") - _, err := hm.Get(7) + _, err := hm.GetWithErr(7) assert.Error(t, err) - assert.Equal(t, hm.GetOrZero(1), "hello") + assert.Equal(t, hm.Get(1), "hello") }