Struct async_io::Timer [−][src]
A future or stream that emits timed events.
Timers are futures that output a single Instant
when they fire.
Timers are also streams that can output Instant
s periodically.
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 emits an event once 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 emits an event once 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 interval(period: Duration) -> Timerⓘ
[src][−]
Creates a timer that emits events periodically.
Examples
use async_io::Timer; use futures_lite::StreamExt; use std::time::{Duration, Instant}; let period = Duration::from_secs(1); Timer::interval(period).next().await;
pub fn interval_at(start: Instant, period: Duration) -> Timerⓘ
[src][−]
Creates a timer that emits events periodically, starting at start
.
Examples
use async_io::Timer; use futures_lite::StreamExt; use std::time::{Duration, Instant}; let start = Instant::now(); let period = Duration::from_secs(1); Timer::interval_at(start, period).next().await;
pub fn set_after(&mut self, duration: Duration)
[src][−]
Sets the timer to emit an en event once after the given 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 emit an event once at the given time instant.
Note that resetting a timer is different from creating a new timer because
set_at()
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);
pub fn set_interval(&mut self, period: Duration)
[src][−]
Sets the timer to emit events periodically.
Note that resetting a timer is different from creating a new timer because
set_interval()
does not remove the waker associated with the
task that is polling the timer.
Examples
use async_io::Timer; use futures_lite::StreamExt; use std::time::{Duration, Instant}; let mut t = Timer::after(Duration::from_secs(1)); let period = Duration::from_secs(2); t.set_interval(period);
pub fn set_interval_at(&mut self, start: Instant, period: Duration)
[src][−]
Sets the timer to emit events periodically, starting at start
.
Note that resetting a timer is different from creating a new timer because
set_interval_at()
does not remove the waker associated with
the task that is polling the timer.
Examples
use async_io::Timer; use futures_lite::StreamExt; use std::time::{Duration, Instant}; let mut t = Timer::after(Duration::from_secs(1)); let start = Instant::now(); let period = Duration::from_secs(2); t.set_interval_at(start, period);
Trait Implementations
impl Debug for Timer
[src][+]
impl Drop for Timer
[src][+]
impl Future for Timer
[src][+]
impl Stream for Timer
[src][+]
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,
impl<T> From<T> for T
[src][+]
impl<F> FutureExt for F where
F: Future + ?Sized,
[src][+]
F: Future + ?Sized,
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,
impl<S> StreamExt for S where
S: Stream + ?Sized,
[src][+]
S: Stream + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src][+]
U: Into<T>,
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src][+]
U: TryFrom<T>,