mirror of https://github.com/milvus-io/milvus.git
35 lines
476 B
Go
35 lines
476 B
Go
package datanode
|
|
|
|
import (
|
|
"sync"
|
|
)
|
|
|
|
type Cache struct {
|
|
cacheMu sync.RWMutex
|
|
cacheMap map[UniqueID]bool
|
|
}
|
|
|
|
func newCache() *Cache {
|
|
return &Cache{
|
|
cacheMap: make(map[UniqueID]bool),
|
|
}
|
|
}
|
|
|
|
func (c *Cache) checkIfCached(key UniqueID) bool {
|
|
c.cacheMu.Lock()
|
|
defer c.cacheMu.Unlock()
|
|
|
|
if _, ok := c.cacheMap[key]; !ok {
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
func (c *Cache) Cache(segID UniqueID) {
|
|
c.cacheMu.Lock()
|
|
defer c.cacheMu.Unlock()
|
|
|
|
c.cacheMap[segID] = true
|
|
}
|