dashmap 3.9.0

Blazing fast concurrent HashMap for Rust.
Documentation
use chashmap::CHashMap;
use criterion::{criterion_group, criterion_main, BenchmarkId, Criterion, Throughput};
use rayon::prelude::*;
use std::cmp;

const ITER: u64 = 8 * 1024;

fn task_insert_chashmap_u64_u64() -> CHashMap<u64, u64> {
    let map = CHashMap::with_capacity(ITER as usize);
    (0..ITER).into_par_iter().for_each(|i| {
        map.insert(i, i + 7);
    });
    map
}

fn insert_chashmap_u64_u64(c: &mut Criterion) {
    let mut group = c.benchmark_group("insert_chashmap_u64_u64");
    group.throughput(Throughput::Elements(ITER as u64));
    let max = cmp::min(num_cpus::get(), 24);

    for threads in &[1, max] {
        group.bench_with_input(
            BenchmarkId::from_parameter(threads),
            &threads,
            |b, &threads| {
                let pool = rayon::ThreadPoolBuilder::new()
                    .num_threads(*threads)
                    .build()
                    .unwrap();
                pool.install(|| b.iter(|| task_insert_chashmap_u64_u64()));
            },
        );
    }

    group.finish();
}

fn task_get_chashmap_u64_u64(map: &CHashMap<u64, u64>) {
    (0..ITER).into_par_iter().for_each(|i| {
        assert_eq!(*map.get(&i).unwrap(), i + 7);
    });
}

fn get_chashmap_u64_u64(c: &mut Criterion) {
    let mut group = c.benchmark_group("get_chashmap_u64_u64");
    group.throughput(Throughput::Elements(ITER as u64));
    let max = num_cpus::get();

    for threads in &[1, max] {
        let map = task_insert_chashmap_u64_u64();

        group.bench_with_input(
            BenchmarkId::from_parameter(threads),
            &threads,
            |b, &threads| {
                let pool = rayon::ThreadPoolBuilder::new()
                    .num_threads(*threads)
                    .build()
                    .unwrap();
                pool.install(|| b.iter(|| task_get_chashmap_u64_u64(&map)));
            },
        );
    }

    group.finish();
}

criterion_group!(benches, insert_chashmap_u64_u64, get_chashmap_u64_u64);
criterion_main!(benches);