Sfoglia il codice sorgente

Check the cache again after getting the lock

Ian Lozinski 9 anni fa
parent
commit
40b3fc319d
1 ha cambiato i file con 3 aggiunte e 0 eliminazioni
  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
 }