Struct std::time::Duration1.3.0 [] [src]

pub struct Duration {
    // some fields omitted
}

A duration type to represent a span of time, typically used for system timeouts.

Each duration is composed of a number of seconds and nanosecond precision. APIs binding a system timeout will typically round up the nanosecond precision if the underlying system does not support that level of precision.

Durations implement many common traits, including Add, Sub, and other ops traits. Currently a duration may only be inspected for its number of seconds and its nanosecond precision.

Examples

fn main() { 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); }
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);

Methods

impl Duration
[src]

fn new(secs: u64, nanos: u32) -> Duration

Creates a new Duration from the specified number of seconds and additional nanosecond precision.

If the 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.

fn from_secs(secs: u64) -> Duration

Creates a new Duration from the specified number of seconds.

fn from_millis(millis: u64) -> Duration

Creates a new Duration from the specified number of milliseconds.

fn as_secs(&self) -> u64

Returns the number of whole seconds represented by this duration.

The extra precision represented by this duration is ignored (e.g. extra nanoseconds are not represented in the returned value).

fn subsec_nanos(&self) -> u32

Returns the nanosecond precision represented by this duration.

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 (e.g. it is less than one billion).

Trait Implementations

impl Add for Duration
[src]

type Output = Duration

The resulting type after applying the + operator

fn add(self, rhs: Duration) -> Duration

The method for the + operator

impl AddAssign for Duration
1.9.0
[src]

fn add_assign(&mut self, rhs: Duration)

The method for the += operator

impl Sub for Duration
[src]

type Output = Duration

The resulting type after applying the - operator

fn sub(self, rhs: Duration) -> Duration

The method for the - operator

impl SubAssign for Duration
1.9.0
[src]

fn sub_assign(&mut self, rhs: Duration)

The method for the -= operator

impl Mul<u32> for Duration
[src]

type Output = Duration

The resulting type after applying the * operator

fn mul(self, rhs: u32) -> Duration

The method for the * operator

impl MulAssign<u32> for Duration
1.9.0
[src]

fn mul_assign(&mut self, rhs: u32)

The method for the *= operator

impl Div<u32> for Duration
[src]

type Output = Duration

The resulting type after applying the / operator

fn div(self, rhs: u32) -> Duration

The method for the / operator

impl DivAssign<u32> for Duration
1.9.0
[src]

fn div_assign(&mut self, rhs: u32)

The method for the /= operator

Derived Implementations

impl Hash for Duration
[src]

fn hash<__H: Hasher>(&self, __arg_0: &mut __H)

Feeds this value into the state given, updating the hasher as necessary.

fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher

Feeds a slice of this type into the state provided.

impl Debug for Duration
[src]

fn fmt(&self, __arg_0: &mut Formatter) -> Result

Formats the value using the given formatter.

impl Ord for Duration
[src]

fn cmp(&self, __arg_0: &Duration) -> Ordering

This method returns an Ordering between self and other. Read more

impl PartialOrd for Duration
[src]

fn partial_cmp(&self, __arg_0: &Duration) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more

fn lt(&self, __arg_0: &Duration) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more

fn le(&self, __arg_0: &Duration) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

fn gt(&self, __arg_0: &Duration) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more

fn ge(&self, __arg_0: &Duration) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Eq for Duration
[src]

impl PartialEq for Duration
[src]

fn eq(&self, __arg_0: &Duration) -> bool

This method tests for self and other values to be equal, and is used by ==. Read more

fn ne(&self, __arg_0: &Duration) -> bool

This method tests for !=.

impl Copy for Duration
[src]

impl Clone for Duration
[src]

fn clone(&self) -> Duration

Returns a copy of the value. Read more

fn clone_from(&mut self, source: &Self)
1.0.0

Performs copy-assignment from source. Read more