#pragma once #include "data_structures/concurrent/common.hpp" #include "data_structures/concurrent/skiplist.hpp" #include "data_structures/concurrent/concurrent_map.hpp" using std::pair; template class ConcurrentBloomMap { using item_t = Item; using list_it = typename SkipList::Iterator; private: ConcurrentMap map_; BloomFilter filter_; public: ConcurrentBloomMap(BloomFilter filter) : filter_(filter) {} std::pair insert(const Key &key, const Value &data) { filter_.insert(key); auto accessor = std::move(map_.access()); return accessor.insert(key, data); } bool contains(const Key &key) { if (!filter_.contains(key)) return false; auto accessor = map_.access(); return accessor.contains(key); } };