Struct std::time::Duration 1.3.0
[−]
[src]
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.
Duration
s implement many common traits, including Add
, Sub
, and other
ops
traits.
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);Run
Methods
impl Duration
[src]
[−]
impl Duration
pub fn new(secs: u64, nanos: u32) -> Duration
[src]
[−]
pub 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
use std::time::Duration; let five_seconds = Duration::new(5, 0);Run
pub const fn from_secs(secs: u64) -> Duration
[src]
[−]
pub const fn from_secs(secs: u64) -> Duration
Creates a new Duration
from the specified number of whole seconds.
Examples
use std::time::Duration; let duration = Duration::from_secs(5); assert_eq!(5, duration.as_secs()); assert_eq!(0, duration.subsec_nanos());Run
pub const fn from_millis(millis: u64) -> Duration
[src]
[−]
pub const fn from_millis(millis: u64) -> Duration
Creates a new Duration
from the specified number of milliseconds.
Examples
use std::time::Duration; let duration = Duration::from_millis(2569); assert_eq!(2, duration.as_secs()); assert_eq!(569_000_000, duration.subsec_nanos());Run
pub const fn from_micros(micros: u64) -> Duration
[src]
[−]
pub const fn from_micros(micros: u64) -> Duration
Creates a new Duration
from the specified number of microseconds.
Examples
#![feature(duration_from_micros)] use std::time::Duration; let duration = Duration::from_micros(1_000_002); assert_eq!(1, duration.as_secs()); assert_eq!(2000, duration.subsec_nanos());Run
pub const fn from_nanos(nanos: u64) -> Duration
[src]
[−]
pub const fn from_nanos(nanos: u64) -> Duration
Creates a new Duration
from the specified number of nanoseconds.
Examples
#![feature(duration_extras)] use std::time::Duration; let duration = Duration::from_nanos(1_000_000_123); assert_eq!(1, duration.as_secs()); assert_eq!(123, duration.subsec_nanos());Run
pub fn as_secs(&self) -> u64
[src]
[−]
pub 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, 730023852); assert_eq!(duration.as_secs(), 5);Run
To determine the total number of seconds represented by the Duration
,
use as_secs
in combination with subsec_nanos
:
use std::time::Duration; let duration = Duration::new(5, 730023852); assert_eq!(5.730023852, duration.as_secs() as f64 + duration.subsec_nanos() as f64 * 1e-9);Run
pub fn subsec_millis(&self) -> u32
[src]
[−]
pub fn subsec_millis(&self) -> u32
Returns the fractional part of this Duration
, in 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
#![feature(duration_extras)] use std::time::Duration; let duration = Duration::from_millis(5432); assert_eq!(duration.as_secs(), 5); assert_eq!(duration.subsec_millis(), 432);Run
pub fn subsec_micros(&self) -> u32
[src]
[−]
pub fn subsec_micros(&self) -> u32
Returns the fractional part of this Duration
, in 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
#![feature(duration_extras, duration_from_micros)] use std::time::Duration; let duration = Duration::from_micros(1_234_567); assert_eq!(duration.as_secs(), 1); assert_eq!(duration.subsec_micros(), 234_567);Run
pub fn subsec_nanos(&self) -> u32
[src]
[−]
pub 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
use std::time::Duration; let duration = Duration::from_millis(5010); assert_eq!(duration.as_secs(), 5); assert_eq!(duration.subsec_nanos(), 10_000_000);Run
pub fn checked_add(self, rhs: Duration) -> Option<Duration>
1.16.0[src]
[−]
pub fn checked_add(self, rhs: Duration) -> Option<Duration>
Checked Duration
addition. Computes self + other
, returning None
if overflow occurred.
Examples
Basic usage:
use std::time::Duration; assert_eq!(Duration::new(0, 0).checked_add(Duration::new(0, 1)), Some(Duration::new(0, 1))); assert_eq!(Duration::new(1, 0).checked_add(Duration::new(std::u64::MAX, 0)), None);Run
pub fn checked_sub(self, rhs: Duration) -> Option<Duration>
1.16.0[src]
[−]
pub fn checked_sub(self, rhs: Duration) -> Option<Duration>
Checked Duration
subtraction. Computes self - other
, returning None
if the result would be negative or if overflow occurred.
Examples
Basic usage:
use std::time::Duration; assert_eq!(Duration::new(0, 1).checked_sub(Duration::new(0, 0)), Some(Duration::new(0, 1))); assert_eq!(Duration::new(0, 0).checked_sub(Duration::new(0, 1)), None);Run
pub fn checked_mul(self, rhs: u32) -> Option<Duration>
1.16.0[src]
[−]
pub fn checked_mul(self, rhs: u32) -> Option<Duration>
Checked Duration
multiplication. Computes self * other
, returning
None
if overflow occurred.
Examples
Basic usage:
use std::time::Duration; assert_eq!(Duration::new(0, 500_000_001).checked_mul(2), Some(Duration::new(1, 2))); assert_eq!(Duration::new(std::u64::MAX - 1, 0).checked_mul(2), None);Run
pub fn checked_div(self, rhs: u32) -> Option<Duration>
1.16.0[src]
[−]
pub fn checked_div(self, rhs: u32) -> Option<Duration>
Checked Duration
division. Computes self / other
, returning None
if other == 0
.
Examples
Basic usage:
use std::time::Duration; assert_eq!(Duration::new(2, 0).checked_div(2), Some(Duration::new(1, 0))); assert_eq!(Duration::new(1, 0).checked_div(2), Some(Duration::new(0, 500_000_000))); assert_eq!(Duration::new(2, 0).checked_div(0), None);Run
Trait Implementations
impl Copy for Duration
[src]
impl Copy for Duration
impl Div<u32> for Duration
[src]
[+]
impl Div<u32> for Duration
impl Debug for Duration
[src]
[+]
impl Debug for Duration
impl Add<Duration> for Duration
[src]
[+]
impl Add<Duration> for Duration
impl Sum<Duration> for Duration
1.16.0[src]
[+]
impl Sum<Duration> for Duration
impl<'a> Sum<&'a Duration> for Duration
1.16.0[src]
[+]
impl<'a> Sum<&'a Duration> for Duration
impl DivAssign<u32> for Duration
1.9.0[src]
[+]
impl DivAssign<u32> for Duration
impl SubAssign<Duration> for Duration
1.9.0[src]
[+]
impl SubAssign<Duration> for Duration
impl Ord for Duration
[src]
[+]
impl Ord for Duration
impl Hash for Duration
[src]
[+]
impl Hash for Duration
impl PartialEq<Duration> for Duration
[src]
[+]
impl PartialEq<Duration> for Duration
impl Mul<u32> for Duration
[src]
[+]
impl Mul<u32> for Duration
impl MulAssign<u32> for Duration
1.9.0[src]
[+]
impl MulAssign<u32> for Duration
impl AddAssign<Duration> for Duration
1.9.0[src]
[+]
impl AddAssign<Duration> for Duration
impl Default for Duration
[src]
[+]
impl Default for Duration
impl Clone for Duration
[src]
[+]
impl Clone for Duration
impl PartialOrd<Duration> for Duration
[src]
[+]
impl PartialOrd<Duration> for Duration
impl Sub<Duration> for Duration
[src]
[+]
impl Sub<Duration> for Duration
impl Eq for Duration
[src]
impl Eq for Duration
impl Add<Duration> for Instant
1.8.0[src]
[+]
impl Add<Duration> for Instant
impl AddAssign<Duration> for Instant
1.9.0[src]
[+]
impl AddAssign<Duration> for Instant
impl Sub<Duration> for Instant
1.8.0[src]
[+]
impl Sub<Duration> for Instant
impl SubAssign<Duration> for Instant
1.9.0[src]
[+]
impl SubAssign<Duration> for Instant
impl Add<Duration> for SystemTime
1.8.0[src]
[+]
impl Add<Duration> for SystemTime
impl AddAssign<Duration> for SystemTime
1.9.0[src]
[+]
impl AddAssign<Duration> for SystemTime
impl Sub<Duration> for SystemTime
1.8.0[src]
[+]
impl Sub<Duration> for SystemTime
impl SubAssign<Duration> for SystemTime
1.9.0[src]
[+]
impl SubAssign<Duration> for SystemTime