Library: Foundation
Package: DateTime
Header: Poco/Timestamp.h
Description
A Timestamp stores a monotonic* time value with (theoretical) microseconds resolution. Timestamps can be compared with each other and simple arithmetics are supported.
[*] Note that Timestamp values are only monotonic as long as the systems's clock is monotonic as well (and not, e.g. set back).
Timestamps are UTC (Coordinated Universal Time) based and thus independent of the timezone in effect on the system.
Member Summary
Member Functions: elapsed, epochMicroseconds, epochTime, fromEpochTime, fromUtcTime, isElapsed, operator !=, operator +, operator +=, operator -, operator -=, operator <, operator <=, operator =, operator ==, operator >, operator >=, resolution, swap, update, utcTime
Types
TimeDiff
difference between two timestamps in microseconds
TimeVal
monotonic UTC time value in microsecond resolution
UtcTimeVal
typedef Int64 UtcTimeVal;
monotonic UTC time value in 100 nanosecond resolution
Constructors
Timestamp
Timestamp();
Creates a timestamp with the current time.
Timestamp
Creates a timestamp from the given time value.
Timestamp
Timestamp(
const Timestamp & other
);
Copy constructor.
Destructor
~Timestamp
~Timestamp();
Destroys the timestamp
Member Functions
elapsed
TimeDiff elapsed() const;
Returns the time elapsed since the time denoted by the timestamp. Equivalent to Timestamp() - *this.
epochMicroseconds
TimeVal epochMicroseconds() const;
Returns the timestamp expressed in microseconds since the Unix epoch, midnight, January 1, 1970.
epochTime
std::time_t epochTime() const;
Returns the timestamp expressed in time_t. time_t base time is midnight, January 1, 1970. Resolution is one second.
fromEpochTime
static Timestamp fromEpochTime(
std::time_t t
);
Creates a timestamp from a std::time_t.
fromUtcTime
static Timestamp fromUtcTime(
UtcTimeVal val
);
Creates a timestamp from a UTC time value.
isElapsed
bool isElapsed(
TimeDiff interval
) const;
Returns true if and only if the given interval has passed since the time denoted by the timestamp.
operator !=
bool operator != (
const Timestamp & ts
) const;
operator +
Timestamp operator + (
TimeDiff d
) const;
operator +=
Timestamp & operator += (
TimeDiff d
);
operator -
Timestamp operator - (
TimeDiff d
) const;
operator -
TimeDiff operator - (
const Timestamp & ts
) const;
operator -=
Timestamp & operator -= (
TimeDiff d
);
operator <
bool operator < (
const Timestamp & ts
) const;
operator <=
bool operator <= (
const Timestamp & ts
) const;
operator =
Timestamp & operator = (
const Timestamp & other
);
operator =
Timestamp & operator = (
TimeVal tv
);
operator ==
bool operator == (
const Timestamp & ts
) const;
operator >
bool operator > (
const Timestamp & ts
) const;
operator >=
bool operator >= (
const Timestamp & ts
) const;
resolution
static TimeVal resolution();
Returns the resolution in units per second. Since the timestamp has microsecond resolution, the returned value is always 1000000.
swap
void swap(
Timestamp & timestamp
);
Swaps the Timestamp with another one.
update
void update();
Updates the Timestamp with the current time.
utcTime
UtcTimeVal utcTime() const;
Returns the timestamp expressed in UTC-based time. UTC base time is midnight, October 15, 1582. Resolution is 100 nanoseconds.