Defined in header <chrono> | ||
---|---|---|
template< class T > struct is_clock; | (since C++20) |
If T
satisfies the Clock requirements, provides the member constant value
equal true
. For any other type, value
is false
.
For the purpose of this trait, the extent to which an implementation determines that a type cannot meet the Clock requirements is unspecified, except that a minimum T
shall not qualify as a Clock unless it meets all of the following conditions:
T::rep
, T::period
, T::duration
, and T::time_point
are all valid and each denotes a type; T::is_steady
and T::now()
are each well-formed when treated as an unevaluated operand. The behavior of a program that adds specializations for is_clock
or is_clock_v
is undefined.
T | - | a type to check |
template< class T > inline constexpr bool is_clock_v = is_clock<T>::value; | (since C++20) |
value
[static] | true if T satisfies the Clock requirements, false otherwise (public static member constant) |
operator bool | converts the object to bool, returns value (public member function) |
operator()
(C++14) | returns value (public member function) |
Type | Definition |
---|---|
value_type | bool |
type | std::integral_constant<bool, value> |
template<class> struct is_clock : std::false_type {}; template<class T> requires requires { typename T::rep; typename T::period; typename T::duration; typename T::time_point; T::is_steady; T::now(); } struct is_clock<T> : std::true_type {}; |
#include <chrono> #include <ratio> int main() { static_assert ( std::chrono::is_clock_v<std::chrono::utc_clock> and not std::chrono::is_clock_v<std::chrono::duration<int, std::exa>> ); }
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/chrono/is_clock