Function futures_util::future::lazy
source · pub fn lazy<F, R>(f: F) -> Lazy<F> ⓘwhere
F: FnOnce(&mut Context<'_>) -> R,
Expand description
Creates a new future that allows delayed execution of a closure.
The provided closure is only run once the future is polled.
Examples
use futures::future;
let a = future::lazy(|_| 1);
assert_eq!(a.await, 1);
let b = future::lazy(|_| -> i32 {
panic!("oh no!")
});
drop(b); // closure is never run