On this page
std::chrono::is_clock
Defined in header <chrono> |
||
---|---|---|
|
(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:
- The qualified-ids
T::rep
,T::period
,T::duration
, andT::time_point
are all valid and each denotes a type; - The expressions
T::is_steady
andT::now()
are each well-formed when treated as an unevaluated operand.
The behavior of a program that adds specializations for std::is_clock
or std::is_clock_v
is undefined.
Template parameters
T | - | a type to check |
Helper variable template
|
(since C++20) |
Inherited from std::integral_constant
Member constants
value
[static]
|
true if T satisfies the Clock requirements, false otherwise (public static member constant) |
Member functions
operator bool
|
converts the object to bool, returns value (public member function) |
operator()
(C++14)
|
returns value (public member function) |
Member types
Type | Definition |
---|---|
value_type |
bool |
type |
std::integral_constant<bool, value> |
Possible implementation
|
Example
#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