std::floating_point
From cppreference.com
Defined in header <concepts> | ||
template<class T > concept floating_point =std::is_floating_point_v<T>; | (since C++20) | |
The concept floating_point<T> is satisfied if and only if T
is a floating-point type.
[edit]Example
Run this code
#include <concepts>#include <iostream>#include <type_traits> constexpr std::floating_pointauto x2(std::floating_pointauto x){return x + x;} constexprstd::integralauto x2(std::integralauto x){return x <<1;} int main(){constexprauto d = x2(1.1); static_assert(std::is_same_v<doubleconst, decltype(d)>);std::cout<< d <<'\n'; constexprauto f = x2(2.2f); static_assert(std::is_same_v<floatconst, decltype(f)>);std::cout<< f <<'\n'; constexprauto i = x2(444); static_assert(std::is_same_v<intconst, decltype(i)>);std::cout<< i <<'\n';}
Output:
2.2 4.4 888
[edit]References
- C++23 standard (ISO/IEC 14882:2024):
- 18.4.7 Arithmetic concepts [concepts.arithmetic]
- C++20 standard (ISO/IEC 14882:2020):
- 18.4.7 Arithmetic concepts [concepts.arithmetic]
[edit]See also
(C++11) | checks if a type is a floating-point type (class template) |