Sha256: 9f4912ca262194cb55e893c33739c85c2f4868d07905b9dd3238552b6ce8a6e4

Contents?: true

Size: 1.31 KB

Versions: 38

Compression:

Stored size: 1.31 KB

Contents

//! Benchmark the overhead that the synchronization of `OnceCell::get` causes.
//! We do some other operations that write to memory to get an imprecise but somewhat realistic
//! measurement.

use once_cell::sync::OnceCell;
use std::sync::atomic::{AtomicUsize, Ordering};

const N_THREADS: usize = 16;
const N_ROUNDS: usize = 1_000_000;

static CELL: OnceCell<usize> = OnceCell::new();
static OTHER: AtomicUsize = AtomicUsize::new(0);

fn main() {
    let start = std::time::Instant::now();
    let threads =
        (0..N_THREADS).map(|i| std::thread::spawn(move || thread_main(i))).collect::<Vec<_>>();
    for thread in threads {
        thread.join().unwrap();
    }
    println!("{:?}", start.elapsed());
    println!("{:?}", OTHER.load(Ordering::Relaxed));
}

#[inline(never)]
fn thread_main(i: usize) {
    // The operations we do here don't really matter, as long as we do multiple writes, and
    // everything is messy enough to prevent the compiler from optimizing the loop away.
    let mut data = [i; 128];
    let mut accum = 0usize;
    for _ in 0..N_ROUNDS {
        let _value = CELL.get_or_init(|| i + 1);
        let k = OTHER.fetch_add(data[accum & 0x7F] as usize, Ordering::Relaxed);
        for j in data.iter_mut() {
            *j = (*j).wrapping_add(accum);
            accum = accum.wrapping_add(k);
        }
    }
}

Version data entries

38 entries across 38 versions & 1 rubygems

Version Path
wasmtime-14.0.3 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-14.0.1 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-14.0.0 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-13.0.0 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-12.0.1 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-12.0.0 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-11.0.0 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-10.0.1 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-10.0.0 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-9.0.4 ./ext/cargo-vendor/once_cell-1.18.0/examples/bench_acquire.rs
wasmtime-9.0.1 ./ext/cargo-vendor/once_cell-1.17.1/examples/bench_acquire.rs
wasmtime-8.0.0 ./ext/cargo-vendor/once_cell-1.17.1/examples/bench_acquire.rs
wasmtime-7.0.0 ./ext/cargo-vendor/once_cell-1.17.1/examples/bench_acquire.rs
wasmtime-6.0.1 ./ext/cargo-vendor/once_cell-1.17.1/examples/bench_acquire.rs
wasmtime-6.0.0 ./ext/cargo-vendor/once_cell-1.17.1/examples/bench_acquire.rs
wasmtime-5.0.0 ./ext/cargo-vendor/once_cell-1.17.0/examples/bench_acquire.rs
wasmtime-0.4.1 ./ext/cargo-vendor/once_cell-1.16.0/examples/bench_acquire.rs
wasmtime-0.4.0 ./ext/cargo-vendor/once_cell-1.16.0/examples/bench_acquire.rs