Package implement Concurrent hash map.
Quoting from [Wikipedia][pds]:
A data structure is partially persistent if all versions can be accessed but only the newest version can be modified. The data structure is fully persistent if every version can be both accessed and modified. If there is also a meld or merge operation that can create a new version from two previous versions, the data structure is called confluently persistent. Structures that are not persistent are called ephemeral data structures.
This implementation of hash map cannot be strictly classified into either of the above definition. It supports concurrent writes, using atomic Load, Store and Cas operations under the hood, and does not provide point in time snapshot for transactional operations or iterative operations.
If point in time snapshots are needed refer to [ppom] package, that implement ordered map with multi-reader concurrency and serialised writes.
key-type
and value-type
.Refer to rustdoc for details.
Initial load of 1 million items, 10 million items and 100 million items
Initial load is single threaded, with u32-bit key and u64-bit values using U32Hasher.
Get operations of 1 million items on 10 million data set
Initial load is single threaded, and subsequently incremental load is repeated with 1-thread, 2-threads, 4-threads, 8-threads, 16-threads using u32-bit key and u64-bit values using U32Hasher.
Set operations of 1 million items on 10 million data set
Initial load is single threaded, and subsequently incremental load is repeated with 1-thread, 2-threads, 4-threads, 8-threads, 16-threads using u32-bit key and u64-bit values using U32Hasher.
Mixed load of of 1 million gets, 50K sets and 50K deletes 10 million data set
Initial load is single threaded, and subsequently incremental load is repeated with 1-thread, 2-threads, 4-threads, 8-threads, 16-threads using u32-bit key and u64-bit values using U32Hasher.
Useful links
make build
to confirm all versions of build is passing with
0 warnings and 0 errors.check.sh
with 0 warnings, 0 errors and all testcases passing.perf.sh
with 0 warnings, 0 errors and all testcases passing.cargo +nightly clippy --all-targets --all-features
to fix clippy issues.cargo spellcheck
to remove common spelling mistakes.