Unified find() interface for all types of containers, with most efficient implementation for each type of container. Requires C++17 compiler.
template <typename C, typename Key>
auto find(C& c, const Key& key);
If element is found, return value evaluates to true and contains iterator to found element. If element is not found, return value evaluates to false and contains hint iterator for insert/emplace.
if (auto i = find(container, key))
{
i->value_member();
container.erase(i);
}
if (auto i = !find(container, key))
{
container.insert(i, expensive_value_construction());
}
- Associative containers: container.lower_bound(...), container.key_comp(...)
- Unordered associative containers: container.find(...)
- Sequence containers: std::find(container, ...)
Tested with the following containers:
std::map
std::multimap
std::unordered_map
std::set
std::multiset
std::unordered_set
boost::container::map
boost::container::set
boost::container::flat_map
boost::container::flat_set
boost::multi_index::ordered_unique
boost::multi_index::ordered_non_unique
boost::multi_index::hashed_unique
boost::multi_index::hashed_non_unique
boost::multi_index::ranked_unique
boost::multi_index::ranked_non_unique
built-in array
std::vector
std::array
std::list