pub struct Duration { /* private fields */ }Expand description
A Duration type to represent a span of time, typically used for system
timeouts.
Each Duration is composed of a whole number of seconds and a fractional part
represented in nanoseconds. If the underlying system does not support
nanosecond-level precision, APIs binding a system timeout will typically round up
the number of nanoseconds.
Durations implement many common traits, including Add, Sub, and other
ops traits. It implements Default by returning a zero-length Duration.
§Examples
use std::time::Duration;
let five_seconds = Duration::new(5, 0);
let five_seconds_and_five_nanos = five_seconds + Duration::new(0, 5);
assert_eq!(five_seconds_and_five_nanos.as_secs(), 5);
assert_eq!(five_seconds_and_five_nanos.subsec_nanos(), 5);
let ten_millis = Duration::from_millis(10);§Formatting Duration values
Duration intentionally does not have a Display impl, as there are a
variety of ways to format spans of time for human readability. Duration
provides a Debug impl that shows the full precision of the value.
The Debug output uses the non-ASCII “µs” suffix for microseconds. If your
program output may appear in contexts that cannot rely on full Unicode
compatibility, you may wish to format Duration objects yourself or use a
crate to do so.
Implementations§
Source§impl Duration
 
impl Duration
Sourcepub const SECOND: Duration
 🔬This is a nightly-only experimental API. (duration_constants #57391)
pub const SECOND: Duration
duration_constants #57391)The duration of one second.
§Examples
Sourcepub const MILLISECOND: Duration
 🔬This is a nightly-only experimental API. (duration_constants #57391)
pub const MILLISECOND: Duration
duration_constants #57391)The duration of one millisecond.
§Examples
Sourcepub const MICROSECOND: Duration
 🔬This is a nightly-only experimental API. (duration_constants #57391)
pub const MICROSECOND: Duration
duration_constants #57391)The duration of one microsecond.
§Examples
Sourcepub const NANOSECOND: Duration
 🔬This is a nightly-only experimental API. (duration_constants #57391)
pub const NANOSECOND: Duration
duration_constants #57391)The duration of one nanosecond.
§Examples
1.53.0 · Sourcepub const MAX: Duration
 
pub const MAX: Duration
The maximum duration.
May vary by platform as necessary. Must be able to contain the difference between
two instances of Instant or two instances of SystemTime.
This constraint gives it a value of about 584,942,417,355 years in practice,
which is currently used on all platforms.
§Examples
1.3.0 (const: 1.58.0) · Sourcepub const fn new(secs: u64, nanos: u32) -> Duration
 
pub const fn new(secs: u64, nanos: u32) -> Duration
Creates a new Duration from the specified number of whole seconds and
additional nanoseconds.
If the number of nanoseconds is greater than 1 billion (the number of nanoseconds in a second), then it will carry over into the seconds provided.
§Panics
This constructor will panic if the carry from the nanoseconds overflows the seconds counter.
§Examples
1.3.0 (const: 1.32.0) · Sourcepub const fn from_secs(secs: u64) -> Duration
 
pub const fn from_secs(secs: u64) -> Duration
Creates a new Duration from the specified number of whole seconds.
§Examples
1.3.0 (const: 1.32.0) · Sourcepub const fn from_millis(millis: u64) -> Duration
 
pub const fn from_millis(millis: u64) -> Duration
Creates a new Duration from the specified number of milliseconds.
§Examples
1.27.0 (const: 1.32.0) · Sourcepub const fn from_micros(micros: u64) -> Duration
 
pub const fn from_micros(micros: u64) -> Duration
Creates a new Duration from the specified number of microseconds.
§Examples
1.27.0 (const: 1.32.0) · Sourcepub const fn from_nanos(nanos: u64) -> Duration
 
pub const fn from_nanos(nanos: u64) -> Duration
Creates a new Duration from the specified number of nanoseconds.
Note: Using this on the return value of as_nanos() might cause unexpected behavior:
as_nanos() returns a u128, and can return values that do not fit in u64, e.g. 585 years.
Instead, consider using the pattern Duration::new(d.as_secs(), d.subsec_nanos())
if you cannot copy/clone the Duration directly.
§Examples
Sourcepub const fn from_weeks(weeks: u64) -> Duration
 🔬This is a nightly-only experimental API. (duration_constructors #120301)
pub const fn from_weeks(weeks: u64) -> Duration
duration_constructors #120301)Sourcepub const fn from_days(days: u64) -> Duration
 🔬This is a nightly-only experimental API. (duration_constructors #120301)
pub const fn from_days(days: u64) -> Duration
duration_constructors #120301)Sourcepub const fn from_hours(hours: u64) -> Duration
 🔬This is a nightly-only experimental API. (duration_constructors #120301)
pub const fn from_hours(hours: u64) -> Duration
duration_constructors #120301)Sourcepub const fn from_mins(mins: u64) -> Duration
 🔬This is a nightly-only experimental API. (duration_constructors #120301)
pub const fn from_mins(mins: u64) -> Duration
duration_constructors #120301)1.53.0 (const: 1.53.0) · Sourcepub const fn is_zero(&self) -> bool
 
pub const fn is_zero(&self) -> bool
Returns true if this Duration spans no time.
§Examples
use std::time::Duration;
assert!(Duration::ZERO.is_zero());
assert!(Duration::new(0, 0).is_zero());
assert!(Duration::from_nanos(0).is_zero());
assert!(Duration::from_secs(0).is_zero());
assert!(!Duration::new(1, 1).is_zero());
assert!(!Duration::from_nanos(1).is_zero());
assert!(!Duration::from_secs(1).is_zero());1.3.0 (const: 1.32.0) · Sourcepub const fn as_secs(&self) -> u64
 
pub const fn as_secs(&self) -> u64
Returns the number of whole seconds contained by this Duration.
The returned value does not include the fractional (nanosecond) part of the
duration, which can be obtained using subsec_nanos.
§Examples
use std::time::Duration;
let duration = Duration::new(5, 730_023_852);
assert_eq!(duration.as_secs(), 5);To determine the total number of seconds represented by the Duration
including the fractional part, use as_secs_f64 or as_secs_f32
1.27.0 (const: 1.32.0) · Sourcepub const fn subsec_millis(&self) -> u32
 
pub const fn subsec_millis(&self) -> u32
Returns the fractional part of this Duration, in whole milliseconds.
This method does not return the length of the duration when represented by milliseconds. The returned number always represents a fractional portion of a second (i.e., it is less than one thousand).
§Examples
1.27.0 (const: 1.32.0) · Sourcepub const fn subsec_micros(&self) -> u32
 
pub const fn subsec_micros(&self) -> u32
Returns the fractional part of this Duration, in whole microseconds.
This method does not return the length of the duration when represented by microseconds. The returned number always represents a fractional portion of a second (i.e., it is less than one million).
§Examples
1.3.0 (const: 1.32.0) · Sourcepub const fn subsec_nanos(&self) -> u32
 
pub const fn subsec_nanos(&self) -> u32
Returns the fractional part of this Duration, in nanoseconds.
This method does not return the length of the duration when represented by nanoseconds. The returned number always represents a fractional portion of a second (i.e., it is less than one billion).
§Examples
1.33.0 (const: 1.33.0) · Sourcepub const fn as_millis(&self) -> u128
 
pub const fn as_millis(&self) -> u128
Returns the total number of whole milliseconds contained by this Duration.
§Examples
1.33.0 (const: 1.33.0) · Sourcepub const fn as_micros(&self) -> u128
 
pub const fn as_micros(&self) -> u128
Returns the total number of whole microseconds contained by this Duration.
§Examples
1.33.0 (const: 1.33.0) · Sourcepub const fn as_nanos(&self) -> u128
 
pub const fn as_nanos(&self) -> u128
Returns the total number of nanoseconds contained by this Duration.
§Examples
1.81.0 (const: 1.81.0) · Sourcepub const fn abs_diff(self, other: Duration) -> Duration
 
pub const fn abs_diff(self, other: Duration) -> Duration
Computes the absolute difference between self and other.
§Examples
1.16.0 (const: 1.58.0) · Sourcepub const fn checked_add(self, rhs: Duration) -> Option<Duration>
 
pub const fn checked_add(self, rhs: Duration) -> Option<Duration>
1.53.0 (const: 1.58.0) · Sourcepub const fn saturating_add(self, rhs: Duration) -> Duration
 
pub const fn saturating_add(self, rhs: Duration) -> Duration
Saturating Duration addition. Computes self + other, returning Duration::MAX
if overflow occurred.
§Examples
1.16.0 (const: 1.58.0) · Sourcepub const fn checked_sub(self, rhs: Duration) -> Option<Duration>
 
pub const fn checked_sub(self, rhs: Duration) -> Option<Duration>
1.53.0 (const: 1.58.0) · Sourcepub const fn saturating_sub(self, rhs: Duration) -> Duration
 
pub const fn saturating_sub(self, rhs: Duration) -> Duration
Saturating Duration subtraction. Computes self - other, returning Duration::ZERO
if the result would be negative or if overflow occurred.
§Examples
1.16.0 (const: 1.58.0) · Sourcepub const fn checked_mul(self, rhs: u32) -> Option<Duration>
 
pub const fn checked_mul(self, rhs: u32) -> Option<Duration>
1.53.0 (const: 1.58.0) · Sourcepub const fn saturating_mul(self, rhs: u32) -> Duration
 
pub const fn saturating_mul(self, rhs: u32) -> Duration
Saturating Duration multiplication. Computes self * other, returning
Duration::MAX if overflow occurred.
§Examples
1.16.0 (const: 1.58.0) · Sourcepub const fn checked_div(self, rhs: u32) -> Option<Duration>
 
pub const fn checked_div(self, rhs: u32) -> Option<Duration>
1.38.0 (const: 1.83.0) · Sourcepub const fn as_secs_f64(&self) -> f64
 
pub const fn as_secs_f64(&self) -> f64
Returns the number of seconds contained by this Duration as f64.
The returned value includes the fractional (nanosecond) part of the duration.
§Examples
1.38.0 (const: 1.83.0) · Sourcepub const fn as_secs_f32(&self) -> f32
 
pub const fn as_secs_f32(&self) -> f32
Returns the number of seconds contained by this Duration as f32.
The returned value includes the fractional (nanosecond) part of the duration.
§Examples
Sourcepub const fn as_millis_f64(&self) -> f64
 🔬This is a nightly-only experimental API. (duration_millis_float #122451)
pub const fn as_millis_f64(&self) -> f64
duration_millis_float #122451)Returns the number of milliseconds contained by this Duration as f64.
The returned value includes the fractional (nanosecond) part of the duration.
§Examples
Sourcepub const fn as_millis_f32(&self) -> f32
 🔬This is a nightly-only experimental API. (duration_millis_float #122451)
pub const fn as_millis_f32(&self) -> f32
duration_millis_float #122451)Returns the number of milliseconds contained by this Duration as f32.
The returned value includes the fractional (nanosecond) part of the duration.
§Examples
1.38.0 · Sourcepub fn from_secs_f64(secs: f64) -> Duration
 
pub fn from_secs_f64(secs: f64) -> Duration
Creates a new Duration from the specified number of seconds represented
as f64.
§Panics
This constructor will panic if secs is negative, overflows Duration or not finite.
§Examples
use std::time::Duration;
let res = Duration::from_secs_f64(0.0);
assert_eq!(res, Duration::new(0, 0));
let res = Duration::from_secs_f64(1e-20);
assert_eq!(res, Duration::new(0, 0));
let res = Duration::from_secs_f64(4.2e-7);
assert_eq!(res, Duration::new(0, 420));
let res = Duration::from_secs_f64(2.7);
assert_eq!(res, Duration::new(2, 700_000_000));
let res = Duration::from_secs_f64(3e10);
assert_eq!(res, Duration::new(30_000_000_000, 0));
// subnormal float
let res = Duration::from_secs_f64(f64::from_bits(1));
assert_eq!(res, Duration::new(0, 0));
// conversion uses rounding
let res = Duration::from_secs_f64(0.999e-9);
assert_eq!(res, Duration::new(0, 1));1.38.0 · Sourcepub fn from_secs_f32(secs: f32) -> Duration
 
pub fn from_secs_f32(secs: f32) -> Duration
Creates a new Duration from the specified number of seconds represented
as f32.
§Panics
This constructor will panic if secs is negative, overflows Duration or not finite.
§Examples
use std::time::Duration;
let res = Duration::from_secs_f32(0.0);
assert_eq!(res, Duration::new(0, 0));
let res = Duration::from_secs_f32(1e-20);
assert_eq!(res, Duration::new(0, 0));
let res = Duration::from_secs_f32(4.2e-7);
assert_eq!(res, Duration::new(0, 420));
let res = Duration::from_secs_f32(2.7);
assert_eq!(res, Duration::new(2, 700_000_048));
let res = Duration::from_secs_f32(3e10);
assert_eq!(res, Duration::new(30_000_001_024, 0));
// subnormal float
let res = Duration::from_secs_f32(f32::from_bits(1));
assert_eq!(res, Duration::new(0, 0));
// conversion uses rounding
let res = Duration::from_secs_f32(0.999e-9);
assert_eq!(res, Duration::new(0, 1));1.38.0 · Sourcepub fn mul_f64(self, rhs: f64) -> Duration
 
pub fn mul_f64(self, rhs: f64) -> Duration
1.38.0 · Sourcepub fn mul_f32(self, rhs: f32) -> Duration
 
pub fn mul_f32(self, rhs: f32) -> Duration
1.38.0 · Sourcepub fn div_f64(self, rhs: f64) -> Duration
 
pub fn div_f64(self, rhs: f64) -> Duration
1.38.0 · Sourcepub fn div_f32(self, rhs: f32) -> Duration
 
pub fn div_f32(self, rhs: f32) -> Duration
1.80.0 (const: 1.83.0) · Sourcepub const fn div_duration_f64(self, rhs: Duration) -> f64
 
pub const fn div_duration_f64(self, rhs: Duration) -> f64
Divides Duration by Duration and returns f64.
§Examples
1.80.0 (const: 1.83.0) · Sourcepub const fn div_duration_f32(self, rhs: Duration) -> f32
 
pub const fn div_duration_f32(self, rhs: Duration) -> f32
Divides Duration by Duration and returns f32.
§Examples
Source§impl Duration
 
impl Duration
1.66.0 · Sourcepub fn try_from_secs_f32(secs: f32) -> Result<Duration, TryFromFloatSecsError>
 
pub fn try_from_secs_f32(secs: f32) -> Result<Duration, TryFromFloatSecsError>
The checked version of from_secs_f32.
This constructor will return an Err if secs is negative, overflows Duration or not finite.
§Examples
use std::time::Duration;
let res = Duration::try_from_secs_f32(0.0);
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f32(1e-20);
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f32(4.2e-7);
assert_eq!(res, Ok(Duration::new(0, 420)));
let res = Duration::try_from_secs_f32(2.7);
assert_eq!(res, Ok(Duration::new(2, 700_000_048)));
let res = Duration::try_from_secs_f32(3e10);
assert_eq!(res, Ok(Duration::new(30_000_001_024, 0)));
// subnormal float:
let res = Duration::try_from_secs_f32(f32::from_bits(1));
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f32(-5.0);
assert!(res.is_err());
let res = Duration::try_from_secs_f32(f32::NAN);
assert!(res.is_err());
let res = Duration::try_from_secs_f32(2e19);
assert!(res.is_err());
// the conversion uses rounding with tie resolution to even
let res = Duration::try_from_secs_f32(0.999e-9);
assert_eq!(res, Ok(Duration::new(0, 1)));
// this float represents exactly 976562.5e-9
let val = f32::from_bits(0x3A80_0000);
let res = Duration::try_from_secs_f32(val);
assert_eq!(res, Ok(Duration::new(0, 976_562)));
// this float represents exactly 2929687.5e-9
let val = f32::from_bits(0x3B40_0000);
let res = Duration::try_from_secs_f32(val);
assert_eq!(res, Ok(Duration::new(0, 2_929_688)));
// this float represents exactly 1.000_976_562_5
let val = f32::from_bits(0x3F802000);
let res = Duration::try_from_secs_f32(val);
assert_eq!(res, Ok(Duration::new(1, 976_562)));
// this float represents exactly 1.002_929_687_5
let val = f32::from_bits(0x3F806000);
let res = Duration::try_from_secs_f32(val);
assert_eq!(res, Ok(Duration::new(1, 2_929_688)));1.66.0 · Sourcepub fn try_from_secs_f64(secs: f64) -> Result<Duration, TryFromFloatSecsError>
 
pub fn try_from_secs_f64(secs: f64) -> Result<Duration, TryFromFloatSecsError>
The checked version of from_secs_f64.
This constructor will return an Err if secs is negative, overflows Duration or not finite.
§Examples
use std::time::Duration;
let res = Duration::try_from_secs_f64(0.0);
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f64(1e-20);
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f64(4.2e-7);
assert_eq!(res, Ok(Duration::new(0, 420)));
let res = Duration::try_from_secs_f64(2.7);
assert_eq!(res, Ok(Duration::new(2, 700_000_000)));
let res = Duration::try_from_secs_f64(3e10);
assert_eq!(res, Ok(Duration::new(30_000_000_000, 0)));
// subnormal float
let res = Duration::try_from_secs_f64(f64::from_bits(1));
assert_eq!(res, Ok(Duration::new(0, 0)));
let res = Duration::try_from_secs_f64(-5.0);
assert!(res.is_err());
let res = Duration::try_from_secs_f64(f64::NAN);
assert!(res.is_err());
let res = Duration::try_from_secs_f64(2e19);
assert!(res.is_err());
// the conversion uses rounding with tie resolution to even
let res = Duration::try_from_secs_f64(0.999e-9);
assert_eq!(res, Ok(Duration::new(0, 1)));
let res = Duration::try_from_secs_f64(0.999_999_999_499);
assert_eq!(res, Ok(Duration::new(0, 999_999_999)));
let res = Duration::try_from_secs_f64(0.999_999_999_501);
assert_eq!(res, Ok(Duration::new(1, 0)));
let res = Duration::try_from_secs_f64(42.999_999_999_499);
assert_eq!(res, Ok(Duration::new(42, 999_999_999)));
let res = Duration::try_from_secs_f64(42.999_999_999_501);
assert_eq!(res, Ok(Duration::new(43, 0)));
// this float represents exactly 976562.5e-9
let val = f64::from_bits(0x3F50_0000_0000_0000);
let res = Duration::try_from_secs_f64(val);
assert_eq!(res, Ok(Duration::new(0, 976_562)));
// this float represents exactly 2929687.5e-9
let val = f64::from_bits(0x3F68_0000_0000_0000);
let res = Duration::try_from_secs_f64(val);
assert_eq!(res, Ok(Duration::new(0, 2_929_688)));
// this float represents exactly 1.000_976_562_5
let val = f64::from_bits(0x3FF0_0400_0000_0000);
let res = Duration::try_from_secs_f64(val);
assert_eq!(res, Ok(Duration::new(1, 976_562)));
// this float represents exactly 1.002_929_687_5
let val = f64::from_bits(0x3_FF00_C000_0000_000);
let res = Duration::try_from_secs_f64(val);
assert_eq!(res, Ok(Duration::new(1, 2_929_688)));Trait Implementations§
1.9.0 · Source§impl AddAssign for Duration
 
impl AddAssign for Duration
Source§fn add_assign(&mut self, rhs: Duration)
 
fn add_assign(&mut self, rhs: Duration)
+= operation. Read more1.9.0 · Source§impl DivAssign<u32> for Duration
 
impl DivAssign<u32> for Duration
Source§fn div_assign(&mut self, rhs: u32)
 
fn div_assign(&mut self, rhs: u32)
/= operation. Read more1.9.0 · Source§impl MulAssign<u32> for Duration
 
impl MulAssign<u32> for Duration
Source§fn mul_assign(&mut self, rhs: u32)
 
fn mul_assign(&mut self, rhs: u32)
*= operation. Read more1.3.0 · Source§impl Ord for Duration
 
impl Ord for Duration
1.3.0 · Source§impl PartialOrd for Duration
 
impl PartialOrd for Duration
1.9.0 · Source§impl SubAssign for Duration
 
impl SubAssign for Duration
Source§fn sub_assign(&mut self, rhs: Duration)
 
fn sub_assign(&mut self, rhs: Duration)
-= operation. Read more