]> git.lizzy.rs Git - rust.git/blob - src/liballoc/benches/vec_deque_append.rs
Stabilize duration_as_u128
[rust.git] / src / liballoc / benches / vec_deque_append.rs
1 #![cfg_attr(stage0, feature(duration_as_u128))]
2 use std::{collections::VecDeque, time::Instant};
3
4 const VECDEQUE_LEN: i32 = 100000;
5 const WARMUP_N: usize = 100;
6 const BENCH_N: usize = 1000;
7
8 fn main() {
9     let a: VecDeque<i32> = (0..VECDEQUE_LEN).collect();
10     let b: VecDeque<i32> = (0..VECDEQUE_LEN).collect();
11
12     for _ in 0..WARMUP_N {
13         let mut c = a.clone();
14         let mut d = b.clone();
15         c.append(&mut d);
16     }
17
18     let mut durations = Vec::with_capacity(BENCH_N);
19
20     for _ in 0..BENCH_N {
21         let mut c = a.clone();
22         let mut d = b.clone();
23         let before = Instant::now();
24         c.append(&mut d);
25         let after = Instant::now();
26         durations.push(after.duration_since(before));
27     }
28
29     let l = durations.len();
30     durations.sort();
31
32     assert!(BENCH_N % 2 == 0);
33     let median = (durations[(l / 2) - 1] + durations[l / 2]) / 2;
34     println!(
35         "\ncustom-bench vec_deque_append {:?} ns/iter\n",
36         median.as_nanos()
37     );
38 }