memgraph/include/data_structures/concurrent/concurrent_set.hpp

78 lines
2.0 KiB
C++
Raw Normal View History

#pragma once
#include "data_structures/concurrent/common.hpp"
#include "data_structures/concurrent/skiplist.hpp"
// Multi thread safe set based on skiplist.
// T - type of data.
template <class T>
class ConcurrentSet
{
2016-08-08 16:32:34 +08:00
typedef SkipList<T> list;
typedef typename SkipList<T>::Iterator list_it;
typedef typename SkipList<T>::ConstIterator list_it_con;
2016-08-08 16:32:34 +08:00
public:
ConcurrentSet() {}
2016-08-08 16:32:34 +08:00
class Accessor : public AccessorBase<T>
{
friend class ConcurrentSet;
2016-08-08 16:32:34 +08:00
using AccessorBase<T>::AccessorBase;
2016-08-08 16:32:34 +08:00
private:
using AccessorBase<T>::accessor;
2016-08-08 16:32:34 +08:00
public:
std::pair<list_it, bool> insert(const T &item)
{
return accessor.insert(item);
}
2016-08-08 16:32:34 +08:00
std::pair<list_it, bool> insert(T &&item)
{
return accessor.insert(std::move(item));
2016-08-08 16:32:34 +08:00
}
2016-08-08 16:32:34 +08:00
list_it_con find(const T &item) const { return accessor.find(item); }
2016-08-08 16:32:34 +08:00
list_it find(const T &item) { return accessor.find(item); }
// Returns iterator to item or first larger if it doesn't exist.
template <class K>
list_it_con find_or_larger(const K &item) const
{
return accessor.find_or_larger(item);
}
// Returns iterator to item or first larger if it doesn't exist.
template <class K>
list_it find_or_larger(const K &item)
{
return accessor.find_or_larger(item);
}
// Returns iterator to item or first larger if it doesn't exist.
template <class K>
list_it_con cfind_or_larger(const K &item)
{
return accessor.template find_or_larger<list_it_con, K>(item);
}
2016-08-08 16:32:34 +08:00
bool contains(const T &item) const
{
return this->find(item) != this->end();
}
2016-08-08 16:32:34 +08:00
bool remove(const T &item) { return accessor.remove(item); }
};
2016-08-08 16:32:34 +08:00
Accessor access() { return Accessor(&skiplist); }
2016-08-08 16:32:34 +08:00
const Accessor access() const { return Accessor(&skiplist); }
2016-08-08 16:32:34 +08:00
private:
list skiplist;
};