[−][src]Struct smol::Timer
A future that expires at a point in time.
Timers are futures that output the Instant
at which they fired.
Examples
Sleep for 1 second:
use async_io::Timer; use std::time::Duration; Timer::after(Duration::from_secs(1)).await;
Timeout after 1 second:
use async_io::Timer; use futures_lite::FutureExt; use std::time::Duration; let addrs = async_net::resolve("google.com:80") .or(async { Timer::after(Duration::from_secs(10)).await; Err(std::io::ErrorKind::TimedOut.into()) }) .await?;
Implementations
impl Timer
[src]
pub fn after(duration: Duration) -> Timerⓘ
[src]
Creates a timer that expires after the given duration of time.
Examples
use async_io::Timer; use std::time::Duration; Timer::after(Duration::from_secs(1)).await;
pub fn at(instant: Instant) -> Timerⓘ
[src]
Creates a timer that expires at the given time instant.
Examples
use async_io::Timer; use std::time::{Duration, Instant}; let now = Instant::now(); let when = now + Duration::from_secs(1); Timer::at(when).await;
pub fn set_after(&mut self, duration: Duration)
[src]
Sets the timer to expire after the new duration of time.
Note that resetting a timer is different from creating a new timer because
set_after()
does not remove the waker associated with the task
that is polling the timer.
Examples
use async_io::Timer; use std::time::Duration; let mut t = Timer::after(Duration::from_secs(1)); t.set_after(Duration::from_millis(100));
pub fn set_at(&mut self, instant: Instant)
[src]
Sets the timer to expire at the new time instant.
Note that resetting a timer is different from creating a new timer because
set_after()
does not remove the waker associated with the task
that is polling the timer.
Examples
use async_io::Timer; use std::time::{Duration, Instant}; let mut t = Timer::after(Duration::from_secs(1)); let now = Instant::now(); let when = now + Duration::from_secs(1); t.set_at(when);
Trait Implementations
Auto Trait Implementations
impl RefUnwindSafe for Timer
impl Send for Timer
impl Sync for Timer
impl Unpin for Timer
impl UnwindSafe for Timer
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut Tⓘ
[src]
impl<T> From<T> for T
[src]
impl<F> FutureExt for F where
F: Future + ?Sized,
[src]
F: Future + ?Sized,
fn or<F>(self, other: F) -> Or<Self, F>ⓘ where
F: Future<Output = Self::Output>,
[src]
F: Future<Output = Self::Output>,
fn race<F>(self, other: F) -> Race<Self, F>ⓘ where
F: Future<Output = Self::Output>,
[src]
F: Future<Output = Self::Output>,
fn boxed<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a + Send>>ⓘ where
Self: Send + 'a,
[src]
Self: Send + 'a,
fn boxed_local<'a>(self) -> Pin<Box<dyn Future<Output = Self::Output> + 'a>>ⓘ where
Self: 'a,
[src]
Self: 'a,
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<F> IntoFuture for F where
F: Future,
[src]
F: Future,
type Output = <F as Future>::Output
into_future
)The output that the future will produce on completion.
type Future = F
into_future
)Which kind of future are we turning this into?
fn into_future(self) -> <F as IntoFuture>::Future
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,