std::floating_point - cppreference.com (original) (raw)
The concept floating_point<T> is satisfied if and only if T
is a floating-point type.
[edit] Example
#include #include #include constexpr std::floating_point auto x2(std::floating_point auto x) { return x + x; } constexpr std::integral auto x2(std::integral auto x) { return x << 1; } int main() { constexpr auto d = x2(1.1); static_assert(std::is_same_v<double const, decltype(d)>); std::cout << d << '\n'; constexpr auto f = x2(2.2f); static_assert(std::is_same_v<float const, decltype(f)>); std::cout << f << '\n'; constexpr auto i = x2(444); static_assert(std::is_same_v<int const, decltype(i)>); std::cout << i << '\n'; }
Output:
[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]