Merge remote-tracking branch 'origin/main'

This commit is contained in:
withchao 2024-09-12 16:50:39 +08:00
commit b2473bc401

View File

@ -100,12 +100,12 @@ func (x *LayLRU[K, V]) GetBatch(keys []K, fetch func(keys []K) (map[K]V, error))
setVs := make(map[K]*layLruItem[V]) setVs := make(map[K]*layLruItem[V])
for _, key := range keys { for _, key := range keys {
v, ok := x.core.Get(key) v, ok := x.core.Get(key)
x.lock.Unlock()
if ok { if ok {
x.lock.Unlock()
v.lock.Lock() v.lock.Lock()
expires, value, err1 := v.expires, v.value, v.err expires, value, err1 := v.expires, v.value, v.err
v.lock.Unlock()
if expires != 0 && expires > time.Now().UnixMilli() { if expires != 0 && expires > time.Now().UnixMilli() {
v.lock.Unlock()
x.target.IncrGetHit() x.target.IncrGetHit()
res[key] = value res[key] = value
if err1 != nil { if err1 != nil {
@ -117,7 +117,6 @@ func (x *LayLRU[K, V]) GetBatch(keys []K, fetch func(keys []K) (map[K]V, error))
} }
} }
queries = append(queries, key) queries = append(queries, key)
x.lock.Unlock()
} }
values, err1 := fetch(queries) values, err1 := fetch(queries)
if err1 != nil { if err1 != nil {