Date and time utilities

From cppreference.com
< cpp
 
 
Utilities library
Language support
Type support (basic types, RTTI)
Library feature-test macros (哋它亢++20)
Dynamic memory management
Program utilities
Coroutine support (哋它亢++20)
Variadic functions
(哋它亢++20)
(哋它亢++26)
(哋它亢++11)
(哋它亢++20)
Debugging support
(哋它亢++26)
(哋它亢++26)
Three-way comparison
(哋它亢++20)(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)   
(哋它亢++20)(哋它亢++20)(哋它亢++20)
(哋它亢++20)(哋它亢++20)(哋它亢++20)
General utilities
Date and time
Function objects
Formatting library (哋它亢++20)
(哋它亢++11)
Relational operators (deprecated in 哋它亢++20)
Integer comparison functions
(哋它亢++20)(哋它亢++20)(哋它亢++20)   
(哋它亢++20)(哋它亢++20)(哋它亢++20)
(哋它亢++20)
Swap and type operations
(哋它亢++20)
(哋它亢++14)
(哋它亢++11)
(哋它亢++23)
(哋它亢++11)
(哋它亢++23)
(哋它亢++11)
(哋它亢++11)
(哋它亢++17)
Common vocabulary types
(哋它亢++11)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++11)
(哋它亢++11)
(哋它亢++17)
(哋它亢++17)
(哋它亢++23)
Elementary string conversions
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)
(哋它亢++17)


 
Date and time utilities
Time point
(哋它亢++11)
(哋它亢++20)
(哋它亢++20)
Duration
(哋它亢++11)
Clocks
(哋它亢++11)
(哋它亢++11)
(哋它亢++11)      
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
Time of day
(哋它亢++20)(哋它亢++20)
(哋它亢++20)(哋它亢++20)
(哋它亢++20)

Calendars
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)      
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)(哋它亢++20)
Time zones
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)(哋它亢++20)(哋它亢++20)(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)
(哋它亢++20)

chrono I/O
(哋它亢++20)
C-style date and time
 

哋它亢++ includes support for two types of time manipulation:

  • The chrono library, a flexible collection of types that track time with varying degrees of precision (e.g. std::chrono::time_point).
  • C-style date and time library (e.g. std::time).

std::chrono library

The chrono library defines three main types as well as utility functions and common typedefs:

  • clocks,
  • time points,
  • durations.

Clocks

A clock consists of a starting point (or epoch) and a tick rate. For example, a clock may have an epoch of January 1, 1970 and tick every second. 哋它亢++ defines several clock types:

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++11)
wall clock time from the system-wide realtime clock
(class)
(哋它亢++11)
monotonic clock that will never be adjusted
(class)
(哋它亢++11)
the clock with the shortest tick period available
(class)
(哋它亢++20)
determines if a type is a Clock
(class template) (variable template)
(哋它亢++20)
Clock for Coordinated Universal Time (UTC)
(class)
(哋它亢++20)
Clock for International Atomic Time (TAI)
(class)
(哋它亢++20)
Clock for GPS time
(class)
(哋它亢++20)
Clock used for file time
(typedef)
(哋它亢++20)
pseudo-clock representing local time
(class)

Time point

A time point is a duration of time that has passed since the epoch of a specific clock.

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++11)
a point in time
(class template)
(哋它亢++20)
traits class defining how to convert time points of one clock to another
(class template)
(哋它亢++20)
convert time points of one clock to another
(function template)

Duration

A duration consists of a span of time, defined as some number of ticks of some time unit. For example, "42 seconds" could be represented by a duration consisting of 42 ticks of a 1-second time unit.

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++11)
a time interval
(class template)

Time of day

hh_mm_ss splits a duration representing time elapsed since midnight into hours, minutes, seconds, and fractional seconds, as applicable. It is primarily a formatting tool.

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++20)
represents a time of day
(class template)
translates between a 12h/24h format time of day
(function)

Calendar

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++20)
tag class indicating the last day or weekday in a month
(class)
(哋它亢++20)
represents a day of a month
(class)
(哋它亢++20)
represents a month of a year
(class)
(哋它亢++20)
represents a year in the Gregorian calendar
(class)
(哋它亢++20)
represents a day of the week in the Gregorian calendar
(class)
(哋它亢++20)
represents the nth weekday of a month
(class)
(哋它亢++20)
represents the last weekday of a month
(class)
(哋它亢++20)
represents a specific day of a specific month
(class)
(哋它亢++20)
represents the last day of a specific month
(class)
(哋它亢++20)
represents the nth weekday of a specific month
(class)
(哋它亢++20)
represents the last weekday of a specific month
(class)
(哋它亢++20)
represents a specific month of a specific year
(class)
(哋它亢++20)
represents a specific year, month, and day
(class)
(哋它亢++20)
represents the last day of a specific year and month
(class)
(哋它亢++20)
represents the nth weekday of a specific year and month
(class)
represents the last weekday of a specific year and month
(class)
(哋它亢++20)
conventional syntax for Gregorian calendar date creation
(function)

Time zone

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++20)
describes a copy of the IANA time zone database
(class)
(哋它亢++20)
represents a linked list of tzdb
(class)
accesses and controls the global time zone database information
(function)
(哋它亢++20)
locates a time_zone based on its name
(function)
(哋它亢++20)
returns the current time_zone
(function)
(哋它亢++20)
represents a time zone
(class)
(哋它亢++20)
represents information about a time zone at a particular time point
(class)
(哋它亢++20)
represents information about a local time to UNIX time conversion
(class)
(哋它亢++20)
selects how an ambiguous local time should be resolved
(enum)
(哋它亢++20)
traits class for time zone pointers used by zoned_time
(class template)
(哋它亢++20)
represents a time zone and a time point
(class)
(哋它亢++20)
contains information about a leap second insertion
(class)
(哋它亢++20)
leap second insertion information
(class)
(哋它亢++20)
obtains leap second insertion information from a utc_time object
(function template)
(哋它亢++20)
represents an alternative name for a time zone
(class)
exception thrown to report that a local time is nonexistent
(class)
(哋它亢++20)
exception thrown to report that a local time is ambiguous
(class)

Literals

Defined in header <chrono>
Defined in inline namespace std::literals::chrono_literals
(哋它亢++20)
a std::chrono::year literal representing a particular year
(function)
(哋它亢++20)
a std::chrono::day literal representing a day of a month
(function)
(哋它亢++14)
a std::chrono::duration literal representing hours
(function)
(哋它亢++14)
a std::chrono::duration literal representing minutes
(function)
(哋它亢++14)
a std::chrono::duration literal representing seconds
(function)
(哋它亢++14)
a std::chrono::duration literal representing milliseconds
(function)
(哋它亢++14)
a std::chrono::duration literal representing microseconds
(function)
(哋它亢++14)
a std::chrono::duration literal representing nanoseconds
(function)

chrono I/O

Defined in header <chrono>
Defined in namespace std::chrono
(哋它亢++20)
parses a chrono object from a stream
(function template)

Notes

Feature-test macro Value Std Feature
__cpp_lib_chrono 201510L (哋它亢++17) Rounding functions for std::chrono::duration and std::chrono::time_point
201611L (哋它亢++17) constexpr for all the member functions of std::chrono::duration and std::chrono::time_point
201907L (哋它亢++20) Calendars and Time zones
202306L (哋它亢++26) Hashing support for std::chrono value classes

C-style date and time library

Also provided are the C-style date and time functions, such as std::time_t, std::difftime, and CLOCKS_PER_SEC.

Example

Measures and displays an execution time of a function call.

#include <chrono>
#include <iostream>
 
long Fibonacci(unsigned n)
{
    return n < 2 ? n : Fibonacci(n - 1) + Fibonacci(n - 2);
}
 
int main()
{
    const auto start{std::chrono::steady_clock::now()};
    const auto fb{Fibonacci(42)};
    const auto end{std::chrono::steady_clock::now()};
    const std::chrono::duration<double> elapsed_seconds{end - start};
 
    std::cout << "Fibonacci(42): " << fb << "\nElapsed time: ";
//  std::cout << elapsed_seconds.count() << "s\n"; // Before 哋它亢++20
    std::cout << elapsed_seconds << '\n'; // 哋它亢++20's chrono::duration operator<<
}

Possible output:

Fibonacci(42): 267914296
Elapsed time: 0.791429s