我用 rust 编写了两个空函数,希望用它们来测试向量上 retain 的使用或在迭代器上 filter 的使用,在为每种情况编写空函数后,在运行程序时,我注意到每个函数的持续时间之间存在巨大差异,这意味着在当前空函数中添加任何逻辑都会导致对其执行时间得出错误的结论。
use std::time::Instant;
fn use_filter() {
}
fn use_retain() {
}
fn run_multiple(f: fn(), times: u64) {
for _ in 0..times {
f()
}
}
fn main() {
let iter_count: u32 = 1_000_000_000;
let _start_1 = Instant::now();
run_multiple(use_filter, iter_count as u64);
let duration = Instant::now() - _start_1;
println!("Use Filter duration: {:?}", duration / iter_count);
let _start_2 = Instant::now();
run_multiple(use_retain, iter_count as u64);
let duration = Instant::now() - _start_2;
println!("Use Retain duration: {:?}", duration / iter_count);
}
预期输出
Use Filter duration: xns
Use Retain duration: xns
其中 x 对于两个函数来说都是相同的,因为它们都是空的并且不执行任何操作
实际产量
Use Filter duration: 8ns
Use Retain duration: 10ns
什么可以解释 rust 编程语言中空函数的执行时间差异很大。