Przeglądaj źródła

Check the cache again after getting the lock

Ian Lozinski 9 lat temu
rodzic
commit
40b3fc319d
1 zmienionych plików z 3 dodań i 0 usunięć
  1. 3 0
      prepared_cache.go

+ 3 - 0
prepared_cache.go

@@ -57,6 +57,9 @@ func (p *preparedLRU) execIfMissing(key string, fn func(lru *lru.Cache) *infligh
 
 	p.mu.Lock()
 	defer p.mu.Unlock()
+	if val, ok := p.lru.Get(key); ok {
+		return val.(*inflightPrepare), true
+	}
 	return fn(p.lru), false
 }