add benchmark to cover in-place extend

This commit is contained in:
The8472 2020-01-25 20:08:46 +01:00
parent a7a8b52e91
commit 6ad133443a

View File

@ -236,6 +236,20 @@ fn do_bench_extend_from_slice(b: &mut Bencher, dst_len: usize, src_len: usize) {
}); });
} }
#[bench]
fn bench_extend_recycle(b: &mut Bencher) {
let mut data = vec![0; 1000];
b.iter(|| {
let tmp = std::mem::replace(&mut data, Vec::new());
let mut to_extend = black_box(Vec::new());
to_extend.extend(tmp.into_iter());
std::mem::replace(&mut data, black_box(to_extend));
});
black_box(data);
}
#[bench] #[bench]
fn bench_extend_from_slice_0000_0000(b: &mut Bencher) { fn bench_extend_from_slice_0000_0000(b: &mut Bencher) {
do_bench_extend_from_slice(b, 0, 0) do_bench_extend_from_slice(b, 0, 0)