2016-07-05 11:01:22 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-08-02 20:23:39 +08:00
|
|
|
#include "data_structures/concurrent/common.hpp"
|
2016-07-31 04:20:21 +08:00
|
|
|
#include "data_structures/concurrent/skiplist.hpp"
|
2016-07-05 11:01:22 +08:00
|
|
|
|
2016-07-31 04:20:21 +08:00
|
|
|
using std::pair;
|
|
|
|
|
2016-07-31 20:56:13 +08:00
|
|
|
template <typename K, typename T>
|
|
|
|
class ConcurrentMap
|
|
|
|
{
|
2016-08-02 20:23:39 +08:00
|
|
|
typedef Item<K, T> item_t;
|
|
|
|
typedef SkipList<item_t> list;
|
|
|
|
typedef typename SkipList<item_t>::Iterator list_it;
|
|
|
|
typedef typename SkipList<item_t>::ConstIterator list_it_con;
|
2016-07-31 04:20:21 +08:00
|
|
|
|
2016-07-31 20:56:13 +08:00
|
|
|
public:
|
2016-07-31 04:20:21 +08:00
|
|
|
ConcurrentMap() {}
|
|
|
|
|
2016-08-02 20:23:39 +08:00
|
|
|
class Accessor : public AccessorBase<item_t>
|
2016-07-31 20:56:13 +08:00
|
|
|
{
|
2016-07-31 04:20:21 +08:00
|
|
|
friend class ConcurrentMap;
|
|
|
|
|
2016-08-02 20:23:39 +08:00
|
|
|
using AccessorBase<item_t>::AccessorBase;
|
2016-07-31 04:20:21 +08:00
|
|
|
|
2016-08-02 20:23:39 +08:00
|
|
|
private:
|
|
|
|
using AccessorBase<item_t>::accessor;
|
2016-07-31 04:20:21 +08:00
|
|
|
|
2016-08-02 20:23:39 +08:00
|
|
|
public:
|
2016-07-31 20:56:13 +08:00
|
|
|
std::pair<list_it, bool> insert(const K &key, const T &data)
|
|
|
|
{
|
2016-08-02 20:23:39 +08:00
|
|
|
return accessor.insert(item_t(key, data));
|
2016-07-31 04:20:21 +08:00
|
|
|
}
|
|
|
|
|
2016-07-31 20:56:13 +08:00
|
|
|
std::pair<list_it, bool> insert(const K &key, T &&data)
|
|
|
|
{
|
2016-08-02 20:23:39 +08:00
|
|
|
return accessor.insert(item_t(key, std::forward<T>(data)));
|
2016-07-31 04:20:21 +08:00
|
|
|
}
|
|
|
|
|
2016-07-31 20:56:13 +08:00
|
|
|
std::pair<list_it, bool> insert(K &&key, T &&data)
|
|
|
|
{
|
2016-08-02 20:23:39 +08:00
|
|
|
return accessor.insert(
|
|
|
|
item_t(std::forward<K>(key), std::forward<T>(data)));
|
2016-07-31 04:20:21 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
list_it_con find(const K &key) const { return accessor.find(key); }
|
|
|
|
|
|
|
|
list_it find(const K &key) { return accessor.find(key); }
|
|
|
|
|
|
|
|
bool contains(const K &key) const { return this->find(key) != this->end(); }
|
|
|
|
|
|
|
|
bool remove(const K &key) { return accessor.remove(key); }
|
|
|
|
};
|
|
|
|
|
|
|
|
Accessor access() { return Accessor(&skiplist); }
|
|
|
|
|
|
|
|
const Accessor access() const { return Accessor(&skiplist); }
|
|
|
|
|
2016-07-31 20:56:13 +08:00
|
|
|
private:
|
2016-07-31 04:20:21 +08:00
|
|
|
list skiplist;
|
2016-07-05 11:01:22 +08:00
|
|
|
};
|