Add separate FlatHashSet.h.

This commit is contained in:
levlam 2022-03-09 23:01:10 +03:00
parent eac8550ec6
commit 7f7344c363
7 changed files with 34 additions and 12 deletions

View File

@ -17,6 +17,7 @@
#include "td/utils/algorithm.h" #include "td/utils/algorithm.h"
#include "td/utils/FlatHashMap.h" #include "td/utils/FlatHashMap.h"
#include "td/utils/FlatHashSet.h"
#include "td/utils/Hints.h" #include "td/utils/Hints.h"
#include "td/utils/logging.h" #include "td/utils/logging.h"
#include "td/utils/misc.h" #include "td/utils/misc.h"

View File

@ -208,6 +208,7 @@ set(TDUTILS_SOURCE
td/utils/find_boundary.h td/utils/find_boundary.h
td/utils/FlatHashMap.h td/utils/FlatHashMap.h
td/utils/FlatHashMapChunks.h td/utils/FlatHashMapChunks.h
td/utils/FlatHashSet.h
td/utils/FlatHashTable.h td/utils/FlatHashTable.h
td/utils/FloodControlFast.h td/utils/FloodControlFast.h
td/utils/FloodControlStrict.h td/utils/FloodControlStrict.h

View File

@ -9,11 +9,9 @@
//#include "td/utils/FlatHashMapChunks.h" //#include "td/utils/FlatHashMapChunks.h"
//#include "td/utils/FlatHashTable.h" //#include "td/utils/FlatHashTable.h"
//#include "td/utils/MapNode.h" //#include "td/utils/MapNode.h"
//#include "td/utils/SetNode.h"
#include <functional> #include <functional>
#include <unordered_map> #include <unordered_map>
#include <unordered_set>
namespace td { namespace td {
@ -22,9 +20,4 @@ template <class KeyT, class ValueT, class HashT = std::hash<KeyT>, class EqT = s
//using FlatHashMap = FlatHashMapChunks<KeyT, ValueT, HashT, EqT>; //using FlatHashMap = FlatHashMapChunks<KeyT, ValueT, HashT, EqT>;
using FlatHashMap = std::unordered_map<KeyT, ValueT, HashT, EqT>; using FlatHashMap = std::unordered_map<KeyT, ValueT, HashT, EqT>;
template <class KeyT, class HashT = std::hash<KeyT>, class EqT = std::equal_to<KeyT>>
//using FlatHashSet = FlatHashTable<SetNode<KeyT>, HashT, EqT>;
//using FlatHashSet = FlatHashSetChunks<KeyT, HashT, EqT>;
using FlatHashSet = std::unordered_set<KeyT, HashT, EqT>;
} // namespace td } // namespace td

View File

@ -0,0 +1,23 @@
//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
#pragma once
//#include "td/utils/FlatHashMapChunks.h"
//#include "td/utils/FlatHashTable.h"
//#include "td/utils/SetNode.h"
#include <functional>
#include <unordered_set>
namespace td {
template <class KeyT, class HashT = std::hash<KeyT>, class EqT = std::equal_to<KeyT>>
//using FlatHashSet = FlatHashTable<SetNode<KeyT>, HashT, EqT>;
//using FlatHashSet = FlatHashSetChunks<KeyT, HashT, EqT>;
using FlatHashSet = std::unordered_set<KeyT, HashT, EqT>;
} // namespace td

View File

@ -184,6 +184,12 @@ class FlatHashTable {
begin_bucket_ = other.begin_bucket_; begin_bucket_ = other.begin_bucket_;
other.drop(); other.drop();
} }
~FlatHashTable() {
if (nodes_ != nullptr) {
clear_nodes(nodes_);
}
}
void swap(FlatHashTable &other) noexcept { void swap(FlatHashTable &other) noexcept {
std::swap(nodes_, other.nodes_); std::swap(nodes_, other.nodes_);
std::swap(used_node_count_, other.used_node_count_); std::swap(used_node_count_, other.used_node_count_);
@ -191,11 +197,6 @@ class FlatHashTable {
std::swap(bucket_count_, other.bucket_count_); std::swap(bucket_count_, other.bucket_count_);
std::swap(begin_bucket_, other.begin_bucket_); std::swap(begin_bucket_, other.begin_bucket_);
} }
~FlatHashTable() {
if (nodes_ != nullptr) {
clear_nodes(nodes_);
}
}
uint32 bucket_count() const { uint32 bucket_count() const {
return bucket_count_; return bucket_count_;

View File

@ -8,6 +8,7 @@
#include "td/utils/common.h" #include "td/utils/common.h"
#include "td/utils/FlatHashMap.h" #include "td/utils/FlatHashMap.h"
#include "td/utils/FlatHashMapChunks.h" #include "td/utils/FlatHashMapChunks.h"
#include "td/utils/FlatHashSet.h"
#include "td/utils/logging.h" #include "td/utils/logging.h"
#include "td/utils/Random.h" #include "td/utils/Random.h"
#include "td/utils/Slice.h" #include "td/utils/Slice.h"

View File

@ -380,6 +380,7 @@ static void BM_cache3(benchmark::State &state) {
} }
} }
} }
template <typename TableT> template <typename TableT>
static void BM_remove_if_slow(benchmark::State &state) { static void BM_remove_if_slow(benchmark::State &state) {
constexpr std::size_t N = 5000; constexpr std::size_t N = 5000;
@ -405,6 +406,7 @@ static void BM_remove_if_slow(benchmark::State &state) {
} }
} }
} }
template <typename TableT> template <typename TableT>
static void BM_remove_if_slow_old(benchmark::State &state) { static void BM_remove_if_slow_old(benchmark::State &state) {
constexpr std::size_t N = 100000; constexpr std::size_t N = 100000;