#data-structures

linked_hash_set

HashSet with insertion ordering

5 releases

0.1.4 Jul 21, 2020
0.1.3 Jun 7, 2018
0.1.2 Feb 24, 2018
0.1.1 Dec 4, 2017
0.1.0 Oct 25, 2017

#201 in Algorithms

Download history 52408/week @ 2023-02-01 54224/week @ 2023-02-08 51504/week @ 2023-02-15 53013/week @ 2023-02-22 54143/week @ 2023-03-01 56738/week @ 2023-03-08 60137/week @ 2023-03-15 59002/week @ 2023-03-22 57754/week @ 2023-03-29 59725/week @ 2023-04-05 63590/week @ 2023-04-12 65299/week @ 2023-04-19 57387/week @ 2023-04-26 59675/week @ 2023-05-03 64102/week @ 2023-05-10 53857/week @ 2023-05-17

246,784 downloads per month
Used in 207 crates (25 directly)

Apache-2.0

58KB
919 lines

linked_hash_set crates.io Documentation

This library provides an hashed set with predictable iteration order, based on the insertion order of elements. It is implemented as a linked_hash_map::LinkedHashMap where the value is (), in a similar way as HashSet is implemented from HashMap in stdlib.

Comparison with std HashSet

General usage is very similar to a traditional hashed set, but this structure also maintains insertion order.

Compared to HashSet, a LinkedHashSet uses an additional doubly-linked list running through its entries. As such methods front(), pop_front(), back(), pop_back() and refresh() are provided.

Comparison with IndexSet

Compared to indexmap::IndexSet, while both maintain insertion order a LinkedHashSet uses a linked list allowing performant removals that don't affect the order of the remaining elements. However, when this distinction is unimportant indexmap should be the faster option.

Example

let mut set = linked_hash_set::LinkedHashSet::new();
assert!(set.insert(234));
assert!(set.insert(123));
assert!(set.insert(345));
assert!(!set.insert(123)); // Also see `insert_if_absent` which won't change order

assert_eq!(set.into_iter().collect::<Vec<_>>(), vec![234, 345, 123]);

Minimum supported rust compiler

This crate is maintained with latest stable rust.

Dependencies

~110KB