2017-02-06 21:38:47 +11:00
|
|
|
use std::collections::VecDeque;
|
2019-11-29 19:30:49 -08:00
|
|
|
use test::{black_box, Bencher};
|
2017-02-06 21:38:47 +11:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_new(b: &mut Bencher) {
|
|
|
|
b.iter(|| {
|
|
|
|
let ring: VecDeque<i32> = VecDeque::new();
|
|
|
|
black_box(ring);
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_grow_1025(b: &mut Bencher) {
|
|
|
|
b.iter(|| {
|
|
|
|
let mut deq = VecDeque::new();
|
|
|
|
for i in 0..1025 {
|
|
|
|
deq.push_front(i);
|
|
|
|
}
|
|
|
|
black_box(deq);
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_iter_1000(b: &mut Bencher) {
|
|
|
|
let ring: VecDeque<_> = (0..1000).collect();
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
let mut sum = 0;
|
|
|
|
for &i in &ring {
|
|
|
|
sum += i;
|
|
|
|
}
|
|
|
|
black_box(sum);
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_mut_iter_1000(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<_> = (0..1000).collect();
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
let mut sum = 0;
|
|
|
|
for i in &mut ring {
|
|
|
|
sum += *i;
|
|
|
|
}
|
|
|
|
black_box(sum);
|
|
|
|
})
|
|
|
|
}
|
2019-02-02 01:29:39 +01:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_try_fold(b: &mut Bencher) {
|
|
|
|
let ring: VecDeque<_> = (0..1000).collect();
|
|
|
|
|
|
|
|
b.iter(|| black_box(ring.iter().try_fold(0, |a, b| Some(a + b))))
|
|
|
|
}
|
2021-08-28 19:46:58 -07:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_from_array_1000(b: &mut Bencher) {
|
|
|
|
const N: usize = 1000;
|
|
|
|
let mut array: [usize; N] = [0; N];
|
|
|
|
|
|
|
|
for i in 0..N {
|
|
|
|
array[i] = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
let deq: VecDeque<_> = array.into();
|
|
|
|
black_box(deq);
|
|
|
|
})
|
|
|
|
}
|
2022-04-11 08:12:14 +02:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_extend_bytes(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<u8> = VecDeque::with_capacity(1000);
|
|
|
|
let input: &[u8] = &[128; 512];
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
ring.clear();
|
|
|
|
ring.extend(black_box(input));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_extend_vec(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<u8> = VecDeque::with_capacity(1000);
|
|
|
|
let input = vec![128; 512];
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
ring.clear();
|
|
|
|
|
|
|
|
let input = input.clone();
|
|
|
|
ring.extend(black_box(input));
|
|
|
|
});
|
|
|
|
}
|
2022-06-11 22:53:46 +02:00
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_extend_trustedlen(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<u16> = VecDeque::with_capacity(1000);
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
ring.clear();
|
|
|
|
ring.extend(black_box(0..512));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_extend_chained_trustedlen(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<u16> = VecDeque::with_capacity(1000);
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
ring.clear();
|
|
|
|
ring.extend(black_box((0..256).chain(768..1024)));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
#[bench]
|
|
|
|
fn bench_extend_chained_bytes(b: &mut Bencher) {
|
|
|
|
let mut ring: VecDeque<u16> = VecDeque::with_capacity(1000);
|
|
|
|
let input1: &[u16] = &[128; 256];
|
|
|
|
let input2: &[u16] = &[255; 256];
|
|
|
|
|
|
|
|
b.iter(|| {
|
|
|
|
ring.clear();
|
|
|
|
ring.extend(black_box(input1.iter().chain(input2.iter())));
|
|
|
|
});
|
|
|
|
}
|