1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
use std::time::{Instant, Duration}; use std::ops::Drop; pub struct Timer { start: Instant, } impl Timer { pub fn start() -> Timer { Timer { start: Instant::now(), } } pub fn stop(self) -> Duration { self.start.elapsed() } } impl Drop for Timer { fn drop(&mut self) { println!("{}", self.start.elapsed().as_millis()); } }