1 | use criterion::{black_box, criterion_group, criterion_main, Criterion}; |
2 | |
3 | fn bench(c: &mut Criterion) { |
4 | use std::sync::atomic::{AtomicUsize, Ordering}; |
5 | |
6 | let mut group = c.benchmark_group("comparison" ); |
7 | group.bench_function("relaxed_load" , |b| { |
8 | let foo = AtomicUsize::new(1); |
9 | b.iter(|| black_box(foo.load(Ordering::Relaxed))); |
10 | }); |
11 | group.bench_function("acquire_load" , |b| { |
12 | let foo = AtomicUsize::new(1); |
13 | b.iter(|| black_box(foo.load(Ordering::Acquire))) |
14 | }); |
15 | group.bench_function("log" , |b| { |
16 | b.iter(|| { |
17 | log::log!(log::Level::Info, "log" ); |
18 | }) |
19 | }); |
20 | group.finish(); |
21 | } |
22 | |
23 | criterion_group!(benches, bench); |
24 | criterion_main!(benches); |
25 | |